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Посвящается нашему миру, изобилующему данными. 
И вам, желающим управлять этими данными. 


501? Почему 
бы не назвать 
книгу Неаа Рігѕї 
$08? 


а Линн Бейли 


Линн — писатель-беллетрист, занявшийся написанием тех- 
нической литературы. Когда обнаружилось, что за техниче- 
ские книги неплохо платят, она приняла свое новое призва- 
ние и стала получать удовольствие от него. 


После получения ученой степени магистра в области ком- 
пьютерных технологий Линн работала в лабораториях МКГ. 
и ГАМІ. Затем она открыла для себя Е1азВ и написала свой 
первый бестселлер. 


Ей не повезло с выбором момента — она переехала в Крем- 
ниевую Долину как раз перед крахом. Линн несколько лет 
проработала в Үаһоо!, писала другие книги и разрабатывала 
учебные курсы. Наконец, поддавшись своим творческим на- 
клонностям, она переехала в Нью-Йорк для получения сте- 
пени магистра искусств в области писательского мастерства. 


Вид из окна Линн. 


Ее дипломная работа, написанная в стиле серии Неаа Еігѕі, 
была представлена в аудитории, плотно забитой профес- 
сорами и однокурсниками. Работа была исключительно 
хорошо принята, Линн получила ученую степень, закончила 
работу над книгой и не может дождаться начала работы над 
следующей книгой. 


Линн любит путешествия, любит готовить и выдумывать 
подробные истории о совершенно незнакомых людях. Не- 
много побаивается клоунов. 


Введение 25 


1 Данные и таблицы: Всему свое место 37 
2 — Команда ЗЕГЕСТ. Выборка данных 87 
з — БЕГЕТЕи ОРРАТЕ: О пользе изменений 153 
4 Проектирование таблиц: Как важно быть нормальным 193 
5  АГСТЕВ: Как изменить прошлое 231 
6 Расширенные возможности ЗЕГЕСТ: Взглянуть на данные 

под другим углом 267 
7 Многотабличные базы данных: Когда в одной таблице тесно 311 

Соединения и многотабличные операции: 

Не могли бы мы остаться в одиночестве? 373 
9 Подзапросы: Запросы внутри запросов 409 
10 Внешние соединения, самосоединения и союзы: 

Новые приемы 445 
11 Ограничения, представления и транзакции: У семи нянек 481 
12 Безопасность: Защита данных 519 
Приложение І: Прочее 549 
Приложение П: Установка МуЅ0]І. 567 
Приложение Ш: Список инструментов 575 


6 одеРжание (настроя шев) 
Введение 


Настройте свой мозг на $01. Вот что вам понадобится, когда 
вы пытаетесь что-то выучить, в то время как ваш мозг не хочет вос- 
принимать информацию. Ваш мозг считает: «Лучше уж я подумаю о 
более важных вещах, например об опасных диких животных или почему 
нельзя голышом прокатиться на сноуборде». Как же заставить свой мозг 


думать, что ваша жизнь зависит от овладения 501? 


Для кого написана эта книга? 26 
Мы знаем, о чем вы думаете 27 
Метапознание: наука о мышлении 29 
Заставить свой мозг повиноваться 31 
Примите к сведению 32 
Технические рецензенты 34 
Благодарности 35 
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Панне и зраб Пиц 


Всему свое место 


Разве не обидно потерять? Что угодно — ключи от машины, 
купон на скидку в 25%, данные приложения... Нет ничего хуже, чем не- 
возможность найти то, что вам нужно... и именно тогда, когда нужно. 

А втом, что касается приложений, для хранения важной информации не 
найти места лучше, чем таблица. Так что переверните страницу и при- 


соединяйтесь к нашей прогулке по миру реляционных баз данных. 


Определение данных 

Рассматриваем данные по категориям 

Что такое «база данных»? 

Посмотрим на базу данных через волшебные очки... 
В базах данных хранится логически связанная информация 
Таблицы под увеличительным стеклом 

Командуйте! 

Создание таблицы: команда СКЕАТЕ ТАВГЕ 
Создание более сложных таблиц 

Посмотрите, как просто пишется код 501, 
Наконец-то создаем таблицу ту _сопасіѕ 

Таблица готова 

Знакомство с типами данных 

Описание таблицы 


Посмотрим на базу данных Нельзя заново создать существующую таблицу или базу данных! 


через Волшебные очки... Долой старые таблицы! 


Для добавления данных в таблицу используется команда ІМЅЕКТ 
Создание команды ПҸЅЕВТ 

Модификации команды ІМЅЕКТ 

Столбцы без значений 

Команда ЗЕГЕСТ читает данные из таблицы 

Управление МОШ. в таблицах 

МОТ МОЦ. в выходных данных ЮрЕЅС 

рЕЕАОІТ и значения по умолчанию 


Новые инструменты 


Кемал ТСТ 


Выборка данных 


При работе с базами данных операция выборки обычно выполня- 


ется чаще, чем операция вставки данных в базу. В этой главе вы познакоми- 


тесь с могущественной командой ЗЕЪЕСТ и узнаете, как получить доступ 


к важной информации, которую вы сохранили в своих таблицах. Также вы 


научитесь использовать условия МНЕКЕ, АМБ и ОВ для избирательной вы- 


борки данных и предотвращения вывода ненужных данных. 


Я — звезда! 


Трудный поиск 

Улучшенная команда ЗЕГЕСТ 

Что это за * ? 

Как запрашивать разные типы данных 

Проблемы со знаками препинания 

Непарный апостроф 

Апострофы как специальные символы 

Команда ПМЗЕКТ с внутренним апострофом 
Выборка ограниченного набора столбцов 

Отбор столбцов ускоряет получение результатов 
Объединение условий 

Поиск числовых значений 

Операторы сравнения 

Операторы сравнения при поиске числовых данных 
Операторы сравнения при поиске текстовых данных 
Быть ИЛЬ не быть 

Чем АМО отличается от ОК 

Испольование 15 МОМ. для поиска МОЦ. 

ГІКЕ: слово для экономии времени 

Специальные символы 


Проверка диапазонов с использованием АМО 
и операторов сравнения 


Только МЕЖДУ нами... Есть и другой способ 
Условие ІМ 

Ключевые слова МОТ ІМ 

Другие применения МОТ 


Новые инструменты 
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ТЕТЕ « (АП. 


О пользе изменений 


Никак не можете прийти к окончательному решению? И ладно! 
Команды, с которыми вы познакомитесь в этой главе — ОЕЪЕТЕ и УРОАТЕ, — 
избавят вас от возни с данными, которые вы ввели полгода назад. Команда 
ЦРРАТЕ изменяет данные, а команда ОЕТЕТЕ удаляет из таблицы данные, 
которые вам больше не нужны. Но мы не только рассмотрим новые инструменты; 
в этой главе вы узнаете, как избирательно применять новые возможности и как 


предотвратить случайное удаление полезных данных. 


Клоуны вокруг нас 154 
Информация о клоунах 155 
Перемещения клоунов 156 
Как вводятся сведения о клоунах 160 
Бонзо, у нас проблема 162 
Уничтожение записей командой ОЕГЕТЕ 163 
Использование команды ВЕГЕТЕ 165 
Правила РЕГЕТЕ 166 
Танцы ПУЗЕКТ-БЕГЕТЕ 169 
Будьте внимательны при выполнении РЕ ЕТЕ 174 
Проблемы с неточными условиями РЕГЕТЕ 178 
Изменение данных командой ОРОАТЕ 180 
Правила ОРРАТЕ 181 
ОРРАТЕ как замена ІҸЅЕКТ-”Е ЕТЕ 182 
ОРРАТЕ в действии 183 
Обновление цен 188 
Достаточно одной команды ОРОАТЕ 190 
Новые нструменты 192 
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Минутку, у меня полная таблица данных. И вы хотите. 
чтобы я удалил ее командой ОВОР ТАВІЕ, кок в гла- 
ве 1, и ввел все данные снова — только для того, чтобы 
создать первичный ключ в кождой записи? 


[р-ектпирование трабЛиц 


Как важно быть нормальным 


До настоящего момента мы не особо задумывались при 
создании таблиц. Работают — и ладно; в конце концов, с ними можно 


выполнять команды 5ЕТЕСТ, ІМЅЕҺТ, ОЕІЕТЕ и ОРРАТЕ. Но при увеличении 


объема данных постепенно становится ясно, что следовало бы сделать при 


создании таблицы для упрощения условий М№УНЕКЕ: ее следовало бы сделать 


более нормальной. 


Две таблицы 

Логические связи как суть таблицы 
Атомарные данные 

Атомарные данные и таблицы 

О пользе нормализации 
Преимущества нормализованных таблиц 
Ненормализованные клоуны 

На полпути к1НФ 

Правила первичных ключей 

Как прийти в НОРМУ 
Исправление таблицы Грега 
Старая команда СКЕАТЕ ТАВГЕ 
Сначала покажи дёењєѓи таблицу 
Команда для экономии времени 


Команда СКЕАТЕ ТАВІЕ с назначением 
первичного ключа 


1, 2, З итак далее 
Добавление первичного ключа в существующую таблицу 
АІТЕЕ ТАВГЕ и добавление первичного ключа 


Новые инструменты 


194 
198 
202 
204 
208 
209 
210 
211 
212 
215 
216 
217 
218 
219 


220 
222 
226 
227 
228 
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АНЯ 


Как изменить прошлое 


Вам никогда не хотелось исправить прошлые ошибки? 

Что же, теперь у вас есть такая возможность. Благодаря команде АЕТЕК 

вы сможете применить свои новые знания к таблицам, созданным много дней, 
месяцев и даже лет назад. А самое замечательное, что это никак не повредит 
существующим данным! К настоящему моменту вы уже знаете, что означает 
понятие нормализованный, и можете применять его ко всем таблицам — 


как прошлым, так и будущим. 


Нужно внести пару изменений 232 
Изменение таблиц 287 
Капитальный ремонт таблицы 238 
Переименование таблицы 239 
Грандиозные планы 241 
Перепланировка столбцов 242 
Структурные изменения 243 
АГСТЕК и СНАМСЕ 244 
Изменение двух столбцов одной командой 501. 245 
Стоп! Никаких лишних столбцов! 249 
Неатомарный столбец Іосаіоп 256 
В поисках закономерности 257 
Удобные строковые функции 258 
Заполнение нового столбца существующими данными 263 
кагана не А Как работает комбинация ОРОАТЕ с 5ЕТ 264 


«бомбу». Вы и не подозревали, что 


такие превращения возможны! Новые инструменты 266 
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Таапиренные ВозЗМоЖностри «ОСТ 
Взглянуть на данные под другим углом 


Пора обзавестись более точными инструментами. вы уже знаете, 
как выполнять выборку данных, и умеете работать с условиями МНЕКЕ. Но в не- 
которых ситуациях нужна точность, на которую ЗЕТЕСТ и МНЕКЕ не способны. 
В этой главе вы научитесь упорядочивать и группировать свои данные, а также 


выполнять математические операции с полученными результатами. 


Перестройка в видеотеке 268 

Недостатки существующей таблицы 269 

Классификация существующих данных 270 

Заполнение нового столбца 971 

ОРРАТЕ с выражением САЅЕ 274 

Похоже, у нас проблемы 276 

Трудности с таблицами 98] 

Упорядочение результатов выборки 282 

ОКРЕК ВУ 285 

Упорядочение по одному столбцу 286 

ОВРЕК с двумя столбцами 289 

р ОКРЕК с несколькими столбцами 290 
АТА пе Упорядоченная таблица 291 
\Мрео рЕЅС и изменение порядка данных 293 
р сж У р Проблемы с печеньем 995 
Ѕ0М сложит числа за нас 297 

Суммирование с использованием СКОТР ВУ 298 

Функция АУС с СКОУР ВУ 299 

МІМ3М и МАХ 300 

СООМТ и подсчет дней 301 

Команда ЗЕГЕСТ РІЅТІМСТ 303 

ЫМИ и ограничение результатов 306 

ЫМП и второе место 307 


Новые нструменты 310 


15 


Маегокаавличные базы данных 


Когда в одной таблице тесно 


Иногда в одной таблице становится попросту тесно. Данные 
стали более сложными, и с одной таблицей работать уже неудобно. Ваша 
единственная таблица забита избыточной информацией, которая только попусту 
расходует место и замедпяет обработку запросов. Вы выжали из одной таблицы 
все, что только можно, но окружающий мир огромен, и для хранения данных 


и работы с ними нередко приходится использовать несколько таблиц. 


Как найти Найджелу подружку 312 
Одной таблицы недостаточно 324 


Многотабличная база данных с информацией о клоунах 325 


Схема базы данных сІомп_їгаскіпр 326 
Как из одной таблицы сделать две 328 
Связывание таблиц 333 
Что нужно знать о внешних ключах 334 
Связи между таблицами 339 
Типы связей: один-к-одному 339 


[зи | Когда используются таблицы со связями 
типа «один-к-одному» 340 
Типы связей: «один-ко-многим» 341 
Типы связей: «многие-ко-многим» 342 
Нам нужна соединительная таблица 345 
неа Типы связей: «многие-ко-многим» 346 
деѕсиртогт 355 

Исправляем таблицу Грега 349 
не Наконец-то — ІНФ... 351 
Составные ключи состоят из нескольких столбцов 352 
Сокращенная запись 354 
Супергеройские зависимости 355 
Частичные функциональные зависимости 355 
Транзитивные функциональные зависимости 356 
Вторая нормальная форма 360 
> Пафеғезћія | Возможно, таблица уже находится в 2НФ... 361 
Третья нормальная форма (наконецто!) 366 

: 
Что делать с таблицей ту _сопќасіѕ? 367 
Новые инструменты 370 
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(‘селинения и МноГотрабЛиЧные операции 


Не могли бы мы остаться в одиночестве? 


Добро пожаловать в многотабличный мир! Базы данных, со- 
стоящие из нескольких таблиц, удобны, но чтобы успешно работать с ними, 
вам придется освоить некоторые новые инструменты и приемы. При работе 
с несколькими таблицами может возникнуть путаница, поэтому вам понадобят 
псевдонимы. А соединения помогут установить связь между таблицами, что 
снова собрать воедино информацию, разбросанную по разным таблицам. При 


готовьтесь, пора снова взять базу данных под свой полный контроль! 


И все равно повторения, повторения... 
Заполнение таблиц 

Проблемы с нормализацией 

Особые увлечения (столбец) 
Разделение увлечений 

Обновление столбцов 

Вывод списка 

Дороги, которые мы выбираем 


(Почти) одновременное выполнение СКЕАТЕ, ЗЕСЕСТ 
и МЗЕКТ 


Одновременное выполнение СКЕАТЕ, ЅЕГЕСТ и ІМЅЕКТ 
Зачем нужно А$? 

Псевдонимы столбцов 

Кому нужны псевдонимы таблиц? 


Все, что вы хотели знать о внутренних соединениях 
„вот откуда 
на самом деле берутся 
таблицы результатов 


Перекрестное соединение 
Открой свое внутреннее соединение 
Внутреннее соединение в действии: эквисоединение 


Внутреннее соединение в действии: неэквивалентное 
соединение 


Последнее внутреннее соединение: естественное 
соединение 


Встроенные запросы? 


Новые инструменты 


ся 
бы 


374 
375 
377 
378 
379 
380 
381 
382 


382 
383 
384 
385 
386 
387 
388 
393 
394 


397 


398 
405 
407 
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[[элзапросы 
Запросы внутри запросов 


Мне, пожалуйста, запрос из двух частей. Соединения — хорошая 
штука, но иногда возникает необходимость обратиться к базе данных сразу 

с несколькими вопросами. Или взять результат одного запроса и исполь- 
зовать его в качестве входных данных другого запроса. В этом вам помогут 
подзапросы, также называемые подчиненными запросами. Они предотвра- 
щают дублирование данных, делают запросы более динамичными и даже 
помогут вам попасть на вечеринку в высшем обществе. (А может, и нет — 


но два из трех тоже неплохо!) 


Грег берется за поиски работы 410 
В списке Грега появляются повые таблицы 411 
Грег использует внутреннее сосдинепие 412 
Но он хочет опробовать другие запросы 414 
Подзапросы 416 
Два запроса преобразуются в запрос с подзапросом 417 
Подзапросы: если одного запроса педостаточно 418 
Подзапрос в действии 419 
Правила для подзапросов 421 
Построение подзапроса 424 
Подзапрос как столбец ЗЕГЕСТ 427 
Другой пример: подзапрос с естествепным соединением 428 
Некоррелированный подзапрос 429 
Некоррелированный подзанрос с несколькими 
значениями: ПМ, МОТ ИМ 433 
Коррелированные подзапросы 438 
ВНЕШН ТИ запрос Коррелированный подзапрос с МОТ ЕХІЅТЅ 439 
ВНУТРЕННИЙ запрос ЕХ15Т$ и МОТ ЕХІЅТЅ 440 
Служба поиска работы Грега прилимает заказы 442 
По дороге на вечеринку 443 
Новые инструменты 444 


Внешний 
запрос 


ЗЕЪЕСТ зоте бо ан 


ЕКОМ +аЬ1е 
МНЕВЕ со1џтп 


апоЕВег со] итп Внуилренний 
к ии 
Запрос 


(ЅЕТЕСТ сои ЕКОМ єаЬ1е) ; 


Внешние соединения, саМосоединенця и союзы 


Новые приемы 


Пока вы знаете только половину того, что необходимо знать 

о соединениях. Вы видели перекрестные соединения, которые возвращают все 
возможные комбинации записей, и внутренние соединения, которые возвращают 
записи обеих таблиц при наличии совпадения. Однако существуют еще и внеш- 
ние соединения, которые возвращают записи, не имеющие совпадений в другой 
таблице, самосоединения, которые (как ни странно) соединяют таблицу саму 


с собой, и союзы, которые объединяют результаты запросов. Освоив эти при- 


емы, вы сможете получить все данные точно в том виде, в котором они вам нужны. 


(И узнаете правду о подзапросах, как мы и обещали!) 


Уничтожение старых данных 446 
Левое, правое... 447 
Пример левого внешнего соединения 448 
Внешние соединения и множественные совпадения 453 
Правое внешнее соединение 454 
Пока мы занимались внешними соединениями... 457 
Создание новой таблицы 458 
Жау Место новой таблицы в схеме 459 
дапные ров Че5" 

Рефлексивный внешний ключ 460 
Соединение таблицы с ней самой 461 
Потребуется самосоединение 463 
Другой способ получения многотабличной информации 464 
ные былч Союзы 465 

8 резул 
должны Ограничения союзов 466 
„расу“ лвобамо ГА я 

А бсих улаблимах Правила союзов в действии 46 

ОМОМ АЦ, 468 

дарила НИ СИСЕМ дан у р 
о 97 ные јоб.4еѕіеа Создание таблицы на основе союза 469 
ІМТЕКЅЕСТ и ЕХСЕРТ 470 
С союзами разобрались, пора переходить к... 471 
Сравнение подзапросов и соединений 471 
я Преобразование подзапроса в соединение 479 

РРО лнныє. Веглречающиеся 

ЕНАЮГА \орец Дан р 
о ЧОФОЯ 6 плаблице 8 обеих илаблицах. исключа Самосоединение как подзапрос 477 
АС КАчебррн кис ыз резцльмлаилов 

ее Компания Грега растет 478 
Новые инструменты 480 
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(граничения, представления и транзакции 


У семи нянек 


Ваша база данных выросла, и теперь с ней будут работать дру- 
гие люди. К сожалению, далеко не все они так же хорошо разбираются в $01, 
как вы. Вам придется позаботиться о том, чтобы предотвратить ввод неверных 
данных, запретить просмотр лишних данных, а также предотвратить возмож- 
ные конфликты при одновременном вводе данных. В этой главе мы займемся 


защитой данных от чужих ошибок. Итак — Защита Баз Данных, часть 1. 


Грег нанимает помощников 482 

Первый день: вставка данных нового клиента 483 

Джим не хочет использовать МОТ, 484 

Три месяца спустя 485 

Добавление ограничения СНЕСК 486 

Ограничение СНЕСК для столбца репаег 487 

Однообразная работа Фрэнка 489 

Создание представления 491 

Просмотр представлений 492 

Как работает представление 493 

Что такое представление 494 

Вставка, обновление и удаление в представлениях 497 

Обновление данных через представление 498 

Представление с СНЕСК ОРТІОМ 501 

Представление может быть обновляемым, если... 502 

Удаление представлений 503 

Когда хорошая база данных плохо ведет себя 504 

Е нее Что произошло с банкоматом 505 
————1—————— Новые неприятности с банкоматами 506 
Ге Это не мечты, а транзакции 508 
Свойства транзакций 509 

ЅОТ. помогает работать с транзакциями 510 

Как должен был работать банкомат 511 

Как работать с транзакциями в Му5ОГ. 512 

Теперь попробуйте сами 513 

Новые инструменты 516 
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гоої 


резопасность 


Защита данных 


Вы потратили массу времени и сил на создание базы данных. 
И если теперь с ней что-нибудь случится, это будет полной катастрофой. Кроме 
того, вам приходится предоставлять другим пользователям доступ к данным, 

и вы опасаетесь, что они могут ошибиться с вставкой или обновлением — или 

и того хуже, удалить нужные данные. В этой главе вы узнаете, как защитить 
базу данных и хранящиеся в ней объекты и как установить контроль над тем, 


какие операции с данными разрешены тем или иным пользователям. 


Проблемы с пользователями 520 
Предотвращение ошибок в базе данных 591 
Защита учетной записи гоої 523 
Создание нового пользователя 524 
Решите, что необходимо каждому пользователю 525 
Простая команда СКАМТ 526 
Разновидности СВАМТ 529 
Команда КЕУОКЕ 530 
Отзыв использованной привилегии СКАМТ ОРТОМ 531 
Проблема общих учетных записей 536 
Использование роли 538 
Удаление ролей 538 
Конструкция ТН АрмМІМ ОРТІОМ 540 
Объединение СВЕАТЕ ОЅЕК с СКАМТ 545 
Оглушительный успех! 546 
Новые инструменты 547 
Присоединяйтесь! 548 


Используйте 501. в своих проектах... и возможно, 
вас тоже ожидает успех! 548 


дос 


] | ] 


дгитру һарру Ѕіееру ѕпееғу 


Прочее 


Десять важнейших тем 
(о которых мы не рассказали) 


Но даже после всего сказанного беседа еще 
чена! Есть еще кое-что, о чем вы должны знать. Мы реш 
неправильно просто проигнорировать эти темы — они за‹ 
бы краткого упоминания. Итак, прежде чем откладывать к 
тесь с этими короткими, но важными разделами. А ког 
те и эту главу, останется еще пара приложений... и может 


рекламы... и ничего больше. Честное слово! 


1. Используйте графический иптерфейс к свое 

2. Зарезервированные слова и специальные си 

3. АСТ, АМҮ и 5ОМЕ 

4. Подробнее о типах данных 

5. Временные таблицы 

6. Преобразование типа 

7. Имя пользователя и текущее время 

8. Полезные числовые функции 

8. Полезные числовые функции (продолжение 

9. Индексирование для ускорения операций 
10. РНР/МУу5ОГ. за две минуты 


707773 
> ЗЕГЕСТ СОКАЕМТ ПАТЕ 


ПАТА ОАТЕ БАТ ОЕАОСАТЕ ОЕС ОЕСІМАІ, ОЕСТАЙЕ ГЕРАРІТ Сі Р 
ОЕЗТАОТ ОЕЗТКОСТОВ 


ЕРЕВААВЕЕ ОКУЖААЕО ОШІЕТЕ 
РЕТЕНИТНТВТЕС ОІСТІОНАКІ ПІАСМОЄТІСЄ СОНВЕНТ ПАТЕ 


ВАСН БІЛЕ БМО ВМО ЕЖШС КОЈАІ5 ЕЗСАРЕ ЖУБАТ ЕХСЕРТ ЕХСЕРТІОН ВХЕС ЖӨЖСОТЕ ЯЛТЕЖНАІ. 


+ 
| 
4 
| 


СЕНЕКА ЧЕТ боЖАЬ 90 Сото 5клит бар СРОСТЕЫС 

ВАУТЖС РОЗТ НОО 

ТРЕИТТТТ ИЗНОЖЕ ІИМЕШТАТЕ 19 ІИОІСАТОВ ІИІТТАІІЛ8 ІИІТІАЈІЛ ІНИЕВ ІСТ ТИРОТ ГИЗЕАТ 
ТИТ ПИТВЈЛА ІИТЖАЗАСТ ТЫТЕВУА:. ТИТО 18 1301АТТОН ГТЕЖАТЕ 

хии 

ЕТ 

ТАМССАСЖ ГАРОЖ ГАЗ ТАТЕВАЕ ТЕАОТИЯ ІКРТ 1888 РУНІ. ВЖЕ 11017 ШОСАЕ ІОСАІТТМА 
ЦОСАЦТТМЕЗТАМР ІОСАТОА 

МАР МАТСН МІНОТЕ МООТРІЕЗ МООІРТ МОЮ МОМТЕ 

МАМЕБ НАТТОМАЬ МАТОВАІ, МСНАА МСІОВ МЕМ МЕЖТ МО МОМЕ НОТ М, ИОМЕАЇС 

ОВЈЕСТ ОР ОТР ОШ ОН ОМІ ОРЕХ ОРЕВАТТОМ ОРТТОМ ОР СТРЕЛ ОВРТИАЫ 

ТАЈ РАВАМЕТЕЯ РАРАМЕТНЕЯ РАЕТТАЕ РАТИ РОЮТЕТЯ РУВСТАТОМ РРЕРІЛ РАЕСЖОЕА РРЕРАЛА 
УРЕЗШИУЕ ТЖТМАИУ РАТОЙ РАТУТААЮЕЯ РВОСЕОХЛЕ ЛС 


> ЗЕЦЕСТ СОААЕМТ ТІМЕ 


ОИВЕНТ ТІМЕ | 


ВВА БАРЕ БЛА МЕСПАБГҮЕ РЕР ВАРЕВЕНСЕЗ АЕРЕЛЕНСІЖЫ РЕІАТГҮЕ ВЕЯТАІСТ ВЕЛЛ ВЕТНИЯ 
ЖЕТОКИЗ АБУОКВ ВІСИТ ВОЦЕ РОЦ.ВАСК РОІЈАЈР РОСТІМЕ АОИ ВСЕ 


ЗАУЕРОТНТ ЗСНЕМА СРО, ЗСОРЕ ЗЕААСИ ЗЕСОМЮ ЗЕСТІОЖ ЗЕЫЕСТ ЗЕСОЕМСЕ 5ЕЗЗТОМ 

БЕЗЗІОН ОЗЕР ЭКТ ЗЕТЗ З15Е ЗМАШАМТ ЗОМЕ ЗРАСЕ ВРЕСТЕТС ЗРЕСІРІСТҮРЕ 901. ЗОБЕЕСЕРТТОМ 
ЗОЪЗТАТЕ ЗОБМАЯН ПАС ВТААТ ЗТАТЕ ВТАТЕМЕМТ УТАТТС ОТИОСТОАЯ БТУТЕМ ОЗЕК 

ТАЛА ТИИРОВААТ ТЕРМІНАТЕ ТАН ТИШН ТІМЕ ТІМЕЗТАМР ТТИБАСНЕ ВОСА ТІМЕІСНЕ МІЗЮОТЕ 12 
ТРАІ ІМС ТКАНЗАСТІОН ТКАМЗБАТІОИ ТРАТ ТВТОСЕВ ТЕЈЕ 


УАІЈЈЕ УАІЈЕЗ УКАСВАК УАРТАВАЕ УААҮТИС УТЕМ 


МНЕН ЯНЕНЕУЕА МНЕКЕ МІТН МТТНООТ МОК МАТТЕ 
ТЕАР 
ВИ Е 


Установка №]. 


Попробуйте сами 


Ваши новые знания принесут пользу только в том слу- 
чае, если вы сможете применить их на практике. В этом 


приложении содержатся инструкции по установке РСУБД МуѕЅаг. 


За дело! 568 
Инструкции и устранение проблем 568 
Установка МуЅОЇ в системе Міпіомѕ 569 
Установка Му$0Г в Мас ОЗ Х 572 


(писек чнстрруМентроВ 


Полный инструментарий $01. 


В этом приложении перечислены все инструменты 500, 
упоминавшиеся в книге. Не жалейте времени, просмотрите весь 


список и возрадуйтесь — ведь вы изучили их все! 
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Введение 


Не могу поверить, что 
они включили такое 
в книгу об 5011 


В эмлом разделе Ме! оилвемли м 


на насущный воирос: 
«Так почему они включили 
ТАКОЕ 6 книгу об 501?» 


Для Кого написана эта Книга? 


Если вы отвегите «да» на все следующие вопросы... 


@) У вас имеется доступ к компьютеру с установленной 


РСУБД — Огасіе, М$ $01 или МуЗОЕЁ? Или 
компьютер, на котором вы ее сможете установить? Мы поможем в 
5 Ам изца 


и КОНмейции и синилаксиг 
СЕ. илак, чилобы по Воз ~ 


мило 
Вы хотите изучить, понять и запомнить принципы 
создания таблиц, баз данных и написания запросов 


ера Ниши иин: Можносили упросилииль его 
понимание и иракиличе - 
Вы предпочитаете оживленную беседу сухим, те ПЕНЕНИЕ 


скучным академическим лекциям? 


...ТО эта книга для вас. 


Кому эта Книга не подойдет? 
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Если вы ответите «да» на любой из следующих вопросов... 


@ 


Ө, 
® 


Но если вам нужно ио - 
Вы абсолютно уверенно разбираетесь в начальном =— билорииль маилериал или 


синтаксисе 501 и ищете книгу о проектировании баз Вы никогда олком не ио - 
данных для экспертов? нимали суиль нормальных 
форм, связей «один-ко- 
Вы уже являетесь опытным программистом и ищете многим» и левых Внешних 
а атаса соединений, — эрла книга 


бам поможеил. 
Вы боитесь попробовать что-нибудь новое? Скорее 
пойдете к зубному врачу, чем наденете полосатое 
с кпетчатым? Считаете, что техническая книга, в которой 
концепции $501 изображены в виде человечков, 
серьезной быть не может? 


е 


...ЭТа книга не для вас. 


[Замеилка оил оилдела продаж: 


боодще-ило эила книга для любого 
Ч кого есиль деньги.] 
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введение 


Мы знаем, о чем Вы думаете 


«Разве серьезные книги по 501, такие?» 


«И почему здесь столько рисунков?» 


«Можно ли так чему-нибудь научиться?» Ван ` 
Чило Эт; д, чилаеил, 
ажно. 
я. 


мы знаем, о чем думает Ваш м0з2 1; 


Мозг жаждет новых впечатлений. Он постоянно ищет, ана- 
лизирует, ожидает чего-то необычного. Он так устроен, и это 
помогает нам выжить. 


Как наш мозг поступает со всеми обычными, повседневными ве- 
щами? Он всеми силами пытается оградиться от них, чтобы они 
не мешали его настоящей работе — сохранению того, что дей- 
ствительно важно. Мозг ие считает нужным сохранять скучную 
информацию. Она не проходит фильтр, отсекающий «очевидно 
несущественное». 


Но как же мозг узнает, что важно? Представьте, что вы выехали 
на прогулку и вдруг прямо перед вами появляется тигр. Что про- 
исходит в вашей голове и теле? 


Активизируются нейроны. Вспыхивают эмоции. Происходят 
химические реакции. 


Замечательно. 
Еще 592 сухие, 
скучные страницы. 


И тогда ваш мозг понимает... 


Конечно, это важно! Не забывать! 


А теперь представьте, что вы находитесь дома или в библиотеке 
в теплом, уютном месте, где тигры не водятся. Вы учитесь — го- 
товитесь к экзамену. Или пытаетесь освоить сложную техниче- 
скую тему, на которую вам выделили неделю... максимум десять 
дней. 


И туг возникает проблема: ваш мозг пытается оказать вам услугу. 
Он старается сделать так, чтобы на эту очевидно несущественную 
информацию не тратились драгоценные ресурсы. Их лучше 
потратить на что-нибудь важное. На тигров, например. Или на 
то, что к огню лучше не прикасаться. Или что на лыжах не стоит 
кататься в футболке и шортах. 


Нет простого способа сказать своему мозгу: «Послушай, мозг, 

я тебе, конечно, благодарен, но какой бы скучной ни была эта 
книга и пусть мой датчик эмоций сейчас на нуле, я хочу запом- 
нить то, что здесь написано». 
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ира книГа ДЛЯ трех, Кро хоЧетр УЧитрься, 


Как мы что-то узнаем? Сначала нужно это «что-то» понять, а потом не забыть. Затол- 
кать в голову побольше фактов недостаточно. Согласно новейшим исследованиям в об- 
ласти когнитивистики, нейробиологии и психологии обучения, для усвоения материала 
требуется что-то большее, чем простой текст на странице. Мы знаем, как заставить ваш 
мозг работать. 


Основные принципы серии «Неаа Еіге?»: 


Наглядность. Графика запоминается гораздо лучше, 
чем обычный текст, и значительно повышает эффек- 
тивность восприятия информации (до 89% по данным 
исследований). Кроме того, материал становится более 
понятным. Текст размещается на рисунках, к которым 
он относится, а не под ними или на соседней странице. 


Разговорный стиль изложения. Недавние 
исследования показали, что при личном 
разговорном стиле изложения материала 
(вместо формальных лекций) улучшение ре- 
зультатов на итоговом тестировании составляло до 40%. Расска- 
зывайте историю, вместо того чтобы читать лекцию. Не относитесь к себе слишком 
серьезно. Что скорее привлечет ваше внимание: занимательная беседа за столом 
или лекция? 


Вам смецяно, наде- 
‚юсь? Ведь я ме клоун 
Смешно, спроимваю? 


Активное участие читателя. Пока вы не начнете напрягать извилины, в вашей 
голове ничего не произойдет. Читатель должен быть заинтересован в результате; 
он должен решать задачи, формулировать выводы и овладевать новыми знаниями. А для 
этого необходимы упражнения и каверзные вопросы, в решении которых задействованы 
оба полушария мозга и разные чувства. 


Привлечение (и сохранение) внимания читателя. Ситуация, знакомая каждому: 
«Я очень хочу изучить это, но засыпаю на первой странице». Мозг обращает внимание на 
интересное, странное, притягательное, неожиданное. Изуче- 
ние сложной технической темы не обязано быть скуч- 
ным. Интересное узнается намного быстрее. 


Оран коми. Вы гожкрите; = Гуротерьте эги ютро- 
Сы» ЭУкочыт, предлололится, что все омм работеьст 
И я вым поверила! Но одын жотрос вообще ме рабола- 
ет. о еще несколько выг ладит сомы тельно, 


Обращение к эмоциям. Известно, что наша способ- 
ность запоминать в значительной мере зависит от эмо- 
ционального сопереживания. Мы запоминаем то, что нам небезразлично. 

Мы запоминаем, когда что-то чувствуем. Нет, сентименты здесь ни 
при чем: речь идет о таких эмоциях, как удивление, любопытство, 
интерес, и чувство «Да я крут!» при решении задачи, которую ( 
окружающие считают сложной — или когда вы понимаете, что / 
разбираетесь в теме лучше, чем всезнайка-Боб из технического е и 
отдела. в -- 2 
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Метапознание: наука о мышлении 


Если вы действительно хотите быстрее и глубже усваивать новые зна- 
ния — задумайтесь над тем, как вы задумываетесь. Учитесь учиться. 


Как бы теперь 
заставить мой 

мозг все это 
запомнить... 


Мало кто из нас изучает теорию метапознания во время учебы. Нам по- 
ложено учиться, но нас редко этому учат. 


Но раз вы читаете эту книгу, то, вероятно, вы хотите изучить ЗОГ., и по 
возможности быстрее. Вы хотите запомнить прочитанное, а для этого о 
абсолютно необходимо сначала понять прочитанное. 


Чтобы извлечь максимум пользы из учебного процесса, нужно заставить 
ваш мозг воспринимать новый материал как Нечто Важное. Критичное 
для вашего существования. Такое же важное, как тигр. Ина- 
че вам предостоит бесконечная борьба с вашим мозгом, 
который всеми силами уклоняется от запоминания новой 
информации. 


Как же УБЕДИТЬ мозг, что язык ЗОЁ не менее важен, 
чем тигр? 


Есть способ медленный и скучный, а есть быстрый и эф- 
фективный. Первый основан на тупом повторении. Всем 
известно, что даже самую скучную информацию можно 
запомнить, если повторять ее снова и снова. При достаточном коли- 
честве повторений ваш мозг прикидывает: «Вроде бы несущественно, но раз 
одно и то же повторяется столько раз... Ладно, уговорил». 


Быстрый способ основан на повышении активности мозга и особенно 
сочетании разных ее видов. Доказано, что все факторы, перечисленные на 
предыдущей странице, помогают вашему мозгу работать на вас. Например, 
исследования показали, что размещение слов внутри рисунков (а не в подпи- 
сях, в основном тексте и т. д.) заставляет мозг анализировать связи между 
текстом и графикой, а это приводит к активизации большего количества 
пейронов. Больше нейронов — выше вероятность того, что информация 
будет сочтена важной и достойной запоминания. 


Разговорный стиль тоже важен: обычно люди проявляют больше внимания, 
когда они участвуют в разговоре, так как им приходится следить за ходом 
беседы и высказывать свое мнение. Причем мозг совершенно не интересует, 
что вы «разговариваете» с книгой! С другой стороны, если текст сух и фор- 
мален, то мозг чувствует то же, что чувствуете вы на скучной лекции в роли 
пассивного участника. Его клонит в сон. 


Но рисунки и разговорный стиль — это только начало. 
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Вот что сделали МЫ: 


Мы использовали рисунки, потому что мозг лучше приспособлен для восприя- 
тия графики, чем текста. С точки зрения мозга рисунок стоит 1024 слов. А когда 
текст комбинируется с графикой, мы внедряем текст прямо в рисунки, потому 
что мозг при этом работает эффективнее. 


Мы используем избыточность: повторяем одно и то же несколько раз, приме- 
няя разные средства передачи информации, обращаемся к разным чувствам — 
и все для повышения вероятности того, что материал будет закодирован в не- 
скольких областях вашего мозга. 


Мы используем концепции и рисунки несколько неожиданным образом, по- 
тому что мозг лучше воспринимает новую информацию. Кроме того, рисунки оуз.оу оха .Ы 
и идеи обычно имеют эмоциональное содержание, потому что мозг обращает 

внимание на биохимию эмоций. То, что заставляет нас чувствовать, лучше запо- 


минается — будь то шутка, удивление или интерес. Г оу зонт; 4 


Мы используем разговорный стиль, потому что мозг лучше воспринимает инфор- 
мацию, когда вы участвуете в разговоре, а не пассивно слушаете лекцию. Это 
происходит и при чтении. 


Веауег 


Каме 


В книгу включены многочисленные упражнения, потому что мозг лучше запо- 
минает, когда вы что-то делаете. Мы постарались сделать их непростыми, но Бесе да у камина 
интересными — то, что предпочитает большинство читателей. м 


Мы совместили несколько стилей обучения, потому что одни читатели предпочи- 
тают пошаговые описания, другие стремятся сначала представить «общую кар- 
тину», а третьим хватает фрагмента кода. Независимо от ваших личных предпо- 
чтений полезно видеть несколько вариантов представления одного материала. 


Мы постарались задействовать оба полушария вашего мозга; это повышает веро- 


ятность усвоения материала. Пока одна сторона мозга работает, другая часто Ё 
имеет возможность отдохнуть; это повышает эффективность обучения в тече- КЛЮЧЕВЫЕ 7 е < 
ние продолжительного времени. МОМЕНТЫ у 


А еще в книгу включены истории и упражнения, отражающие другие точки 
зрения. Мозг глубже усваивает информацию, когда ему приходится оценивать 
и выносить суждения. 


В книге часто встречаются вопросы, на которые не всегда можно дать простой 
ответ, потому что мозг быстрее учится и запоминает, когда ему приходится что- 
то делать. Невозможно накачать мышцы, наблюдая за тем, как занимаются дру- 
гие. Однако мы позаботились о том, чтобы усилия читателей были приложены 
в верном направлении. Вам не придется ломать голову над невразумительными 
примерами или разбираться в сложном, перенасыщенном техническим жарго- 
ном или слишком лаконичном тексте. 


В историях, примерах, на картинках используются люди — потому что вы тоже 
человек. И ваш мозг обращает на людей больше внимания, чем на неодушевлен- 
ные предметы. 
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Что можете сделать БЫ, чтобы 
заставить сбои моз? побиноВаться 


Мы свое дело сделали. Остальное за вами. Эти советы станут 
отправной точкой; прислушайтесь к своему мозгу и определи- 
те, что вам подходит, а что не подходит. Пробуйте новое. 


Вырежьиле 


и прикрелциде 
На холодильник. 


@ Не торопитесь. Чем больше вы поймете, Ф Говорите вслух. 


тем меньше придется запоминать. 


Просто читать недостаточно. Когда 
книга задает вам вопрос, не переходите 
к ответу. Представьте, что кто-то дей- 
ствительно задает вам вопрос. Чем глуб- 
же ваш мозг будет мыслить, тем скорее 
вы поймете и запомните материал. 


Выполняйте упражнения, делайте заметки. 
Мы включили упражнения в книгу, но 
выполнять их за вас не собираемся. И не 
фазглядывайтг упражнения. Берите ка- 
рандаш и пишите Физические действия 
во время учения повышают его эффектив- 
НОСТЬ. 


Читайте врезки. 
Это значит: читайте все. Врезки — часть 
основного материала! Не пропускайте их. 


Не читайте другие книги после этой перед сном. 


Часть обучения (особепно перенос 
информации в долгосрочную память) про- 
исходит после того, как вы откладываете 
книгу. Ваш мозг не сразу усваивает инфор- 
мацию. Если во время обработки посту- 
пит новая информация, часть того, что 
вы узнали ранее, может быть потеряна. 


Пейте воду. И побольше. 

Мозг лучше всего работает в условиях вы- 
сокой влажности. Дегидратация (которая 
может наступить еще до того, как вы по- 
чувствуете жажду) снижает когнитивные 
функции. 


Речь активизирует другие участки моз- 

га. Если вы пытаетесь что-то понять или 
получше запомнить, произнсситс вслух. 

А еще лучше — попробуйте объяснить 
кому-нибудь другому. Вы будете быстрее 
усваивать материал и, возможно, откроете 
для себя что-то новое. 


Прислушивайтесь к своему мозгу. 

Следите за тем, когда ваш мозг начинает 
уставать. Если вы начинаете поверхностпо 
воспринимать материал или забываете 
ТОЛЬКО ЧТО прочитанное — пора сделать 
перерыв. 


Чувствуйте! 

Ваш мозг должен знать, что материал 
книги действительно важен. Переживайтс 
за героев наших историй. Придумывайте 
собственные подписи к фотографиям. По- 
морщиться над неудачной шуткой все равно 
лучше, чем не почувствовать ничего. 


@® Творите! 


Попробуйте применить новые знания 

в своей повседневной работе. Просто 
сделайте хоть что-нибудь, чтобы приобрести 
практический опыт за рамками упражие- 
ний. Все, что для этого нужно — это каран- 
даш и подходящая задача... задача, в ко- 
торой изучаемые методы и инструменты 
могут принести пользу. 
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Примите К сведению 


Это учебник, а не справочник. Мы намеренно убрали из книги все, что могло бы 
помешать изучению материала, над которым вы работаете. И при первом чтении 
книги начинать следует с самого начала, потому что книга предполагает наличие 
у читателя определенных знаний и опыта. 


Мы начинаем с основного синтаксиса $01, а затем переходим 
к проектированию баз данных $01 и построению нетривиальных запросов. 


Правильное проектирование таблиц и баз данных — дело, конечно, важное, 

но сначала необходимо понять синтаксис 501. Поэтому наш учебный курс на- 
чинается с команд ЗОГ, которые вы можете опробовать сами. А когда это у вас 
получится, вы начнете испытывать интерес к теме. Затем, в более поздних главах 
книги, мы опишем правила проектирования таблиц. К этому времени вы уже 
будете хорошо понимать необходимый синтаксис и сможете сосредоточиться 

на изучении концепций. 


Мы не пытаемся описать все без исключения команды, функции 
и ключевые слова $01. 


Теоретически мы могли бы включить в книгу описание всех команд, функций 

и ключевых слов, но читатель, вероятно, предпочтет иметь дело с книгой, КОТО- 
рую можно сдвинуть с места. Поэтому мы приводим лишь тот материал, который 
действительно абсолютно необходим — то, чем вы будете пользоваться в 95% слу- 
чаев. А после прочтения книги вы сможете без проблем найти описание нужной 
функции в справочнике. 


Мы не описываем все тонкости синтаксиса для всех разновидностей $01. 


Существует много разных РСУБД: Ѕ‹апаага ЗОГ, МуЅОІ, Огафе, М$ ОТ. Ѕегуег, 
Розхетез ОГ, ОВ2... и это еще не все. Если бы мы стали описывать все различия 

в синтаксисе всех команд, то книга стала бы во много раз толщее, поэтому в книге 
основное внимание уделяется стандартному синтаксису ЗОГ, с небольшим укло- 
ном в сторону Му5ОГ. Все примеры книги будут работать в Му5ОГ.. Кроме того, 
большинство из них будет работать во всех перечисленных выше РСУБД. Пом- 
ните, ранее мы советовали купить справочник? Так вот, купите специализирован- 
ный справочник для той РСУБД, с которой вы работаете. 


Упражнения ОБЯЗАТЕЛЬНЫ. 


Упражнения являются частью основного материала книги. Одни упражнения спо- 
собствуют запоминанию материала, другие помогают лучше понять его, третьи 
ориентированы на его практическое применение. Не пропускайте упражнения. 
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Повторение применяется намеренно. 


У книг этой серии есть одна принципиальная особенность: мы хотим, чтобы вы 
действительно хорошо усвоили материал. И чтобы вы запомнили все, что узнали. 
Большинство справочников не ставит своей целью успешное запоминание, но это 
не справочник, а учебник, поэтому некоторые концепции излагаются в книге по 
нескольку раз. 


Примеры кода были сделаны по возможности компактными. 


Наши читатели не любят просматривать по 200 строк кода, чтобы найти две нуж- 
ные строки. Большинство примеров книги приводится в минимальном контексте, 
чтобы та часть, которую вы непосредственно изучаете, была понятной и простой. 
Не ждите, что весь код будет стопроцентно устойчивым или даже просто завер- 
шенным — примеры написаны в учебных целях и не всегда являются полнофунк- 
циональными. 


Многие команды доступны в Интернете, чтобы вы могли скопировать их для 
выполнения в своем терминале или рабочей программе. Их можно загрузить 
по адресу Һер: / /мим . һеадбгѕё1арѕ .сош/Боок$/ВЕза1/ 


Упражнения «Игры разума» не имеют ответов. 


В некоторых из них правильного ответа вообще нет, в других вы должны сами 
решить, насколько правильны ваши ответы (это является частью процесса обуче- 
ния). В некоторых упражнениях «Игры разума» приводятся подсказки, которые 
помогут вам найти нужное направление. 


Установка сервера $аї!. 


Чтобы создавать базы данных и таблицы средствами 501, а также работать 

с ними, вам понадобится доступ к серверу $01. Возможно, на вашем веб-сервере 
уже имеется установленная и настроенная РСУБД, а если нет — установите ее на 
своем домашнем компьютере. В приложении іі приведены инструкции по установ- 
кс Му5ОГ. (популярная бесплатная реализация 501) для Мас и Міпаом. 


ЗОЕ для ленивых. 


Если вам не хочется возиться с установкой РСУБД на своем компьютере 

и вы просто хотите самостоятельно проверить примеры, приведенные в книге, 
вам повезло! Мы создали специальную «ЗОГ-песочницу», в которой вы можете 
поиграть и поэкспериментировать с большинством примеров. Посетите страницу 
по адресу ЪЕЕр: / /мим .БеаЯЯтз1аЪ$ .сот/з91 Һапаѕз оп/ 
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Технические рецензенты 


Кэри Коллеилил 


Силив Милано 


Чосер пложе 
помогал. 


Джейми Хендерсон 


Наши замечательные рецензенты 


Мы бесконечно благодарны нашим техническим 
рецензентам, вылавливавшим бесчисленные 
грубые ляпсусы, коварные ошибки и банальные 
опечатки. Без них материал книги не был бы 

и наполовину таким четким и правильным. Они 
отлично справились со своей работой. 


Кэри Коллетт применил 15 лет практического 
опыта, полученного во время работы в начинаю- 
щих фирмах, правительственных лабораториях 
и финансовом секторе, в ходе рецензирования 
этой книги. Сейчас он надеется вернуться к дру- 
гим приятным занятиям, не связанным с рабо- 
той, — кулинарии, туризму, чтению книг и развле- 
чениям с собаками. 


Лу-Энн Мазза выкроила немного времени из своей 
занятой профессиональной жизни программиста 
и аналитика для написания исключительно точных 
и актуальных рецензий. Мы рады, что теперь она 
сможет уделять больше времени своим увлече- 
ниями — велоспорту, фотографии, компьютерам, 
музыке и теннису. 


Когда Стив Милано не программирует на по- 
лудюжине разных языков, не пишет рецензии 
по книгам и не играет в группе панк-рока Опіоп 
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Науогеа Кіпрѕ в плохо проветриваемых подвалах 
по всей стране, обычно он сидит дома со своими 
котами Ральфом и Сквиком. 


«Шелли» Мойра Мишель Римс, магистр педа- 
гогических наук, обладательница сертификатов 
МСР и МСЕ, ведет образовательные программы 
для детей младшего возраста в общественном 
колледже Дельгадо (Нью-Орлеан). В настоящее 
время она переводит свои учебные курсы в ин- 
тернет-формат, чтобы обеспечить изменившиеся 
потребности населения Нью-Орлеана после ура- 
гана «Катрина». Мы благодарны ей за то, что она 
смогла выбрать для нас время в своем плотном0 
графике. 


Джейми Хендерсон — ведущий специалист по 
системным архитектурам. Ее волосы выкрашены 
в фиолетовый цвет, а свободное время делит- 

ся между виолончелью, книгами, видеоиграми 

и фильмами на РУО. 


Благодаря этой замечательной группе код 

и упражнения в книге делают именно то, что им 
положено делать, а читатель, перевернув послед- 
нюю страницу, начнет вполие уверенно програм- 
мировать на 50]. 


Благодарности 


Редакторы 


Прежде всего хочу поблагодарить своего редактора Бретта Маклаф- 
лина за целых два учебных курса по серии Неаа Е. Бретт не просто 
редактор — умение выслушать собеседника сочетается с готовностью 
помочь. Без его руководства, поддержки и интереса эта книга никогда 
не была бы написана. Он не только понял меня с первого собеседова- 
ния, но и благожелательно относился к моему (порой чрезмерному) 
юмору. В результате эта книга стала самым лучшим из всех моих автор- 
ских проектов. Бретт дал мне много полезных советов, и благодаря 
ему я узнала много полезного в ходе работы. Спасибо, Бретт! 


Редактор Кэтрин Нолан наверняка потеряла немало Бреилил 
нервных клеток из-за того, что мне очень сильно не Маклафлин 
повезло в конце процесса редактирования. Возможно, 

только благодаря ей эта книга все-таки вышла в свет. 

Опа управлялась с проектом виртуозно, словно жонглер, 

и ухитрилась ничего не уронить. Мне был отчаянно 

необходим четко расписанный план, а Кэтрин — луч- 

ший планировщик из всех, кого я когда-либо встречала. 

Вероятно, я создала ей больше всего проблем. Будем 

надеяться, что следующий проект Кэтрин пройдет более 

гладко — она это заслужила! 


~ оэидрин Нолан 


Сотрудники издательства О’ВЌеШу 


Художественный редактор Луиза Барр была для нас хорошим другом и талантли- 
вым дизайнером. Каким-го образом ей удалось преобразовать мои безумные идеи 
во впечатляющие художественные образы, которые предельно ясно передают са- 
мые сложные концепции. Вся работа по дизайну была выполнена ей, и я уверена, 
что на многих страницах книги вам захочется поблагодарить ее вместе со мной. 


Книга наверняка содержала бы массу ошибок, если бы не процесс технического 
рецензирования. Сандерс Клейнфилд отлично справился с работой редактора 
но производству и подготовил книгу к печати. Кроме того, он вышел далеко за 
рамки своих прямых обязанностей и указал целый ряд концептуальных пробе- 
лов, которые действительно стоило заполнить. Спасибо, Сандерс! 


Наконец, я хочу поблагодарить Кэти Сьерра и Берта Бэйтса за создание этой 
замечательной серии и за самый лучший и напряженный учебный курс, который 
мие довелось пройти за свою жизнь. Если бы не эти три дня — даже не хочу думать, 
насколько сложнее мне было бы работать над книгой. Завершающие комментарии 
Берта отличались беспощадной точностью и значительно улучшили эту книгу. 
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1 | анньзе и паёбЛиЦць 


* 
є. Всему свое место * 


Раньше я хранила 
истории болезни на бумаге, но 
они постоянно терялись. А теперь 
я изучила 501, и у меня ничего не 
потеряется! Вот как полезно знать, 
что такое таблицы! 


Разве не обидно потерять? Что угодно — ключи от маши- 
ны, купон на скидку в 25%, данные приложения... Нет ничего хуже, 
чем невозможность найти то, что вам нужно... и именно тогда, 
когда нужно. А в том, что касается приложений, для хранения 
важной информации не найти места лучше, чем таблица. Так что 
переверните страницу и присоединяйтесь к нашей прогулке 


по миру реляционных баз данных. 


Определение данных 


У Грега много друзей. Он обожает знакомить их | 
друг с другом, но, конечно, для этого ему нужно | 
помнить, кто чем увлекается. Грег аккуратно запи- 

сывает подробную информацию на листочках: 


Грег уже очень давно использует свою систему. 
А на прошлой неделе он решил включить в нее 
людей, занимающихся поисками работы, так 

что его каталог быстро растет. Очень быстро... 
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А 


мот туте 
ГР — 


я т 


Рожониа Ма? АА 
Беедшая суотралми ейн бнаа аа 
ра телесна 


м рое лоок 


а анаан данны Б Даса рет оныа аага р 


инчо ретіне аяне д 


Нет ли более разумного способа хранения этой 
информации? А что бы сделали ВЫ на его месте? 


96 зи... 
Как насчет базы данных? 


Ведь книга написана о базах 
данных, верно? 


Абсолютно верно. База данных — 
именно то, что нам нужно. 


Но прежде чем браться за создание ба- 
зы данных, необходимо получше разо- 
браться в том, какие виды данных будут 
в ней храниться и на какие категории 
они будут разделены. 


Возьми в руку карандаш 


е, 
Б" Перед вами несколько карточек из каталога Грега. Найдите 
С сходные данные, собранные Грегом о каждом человеке. При- 
свойте таким данным метку, описывающую категорию инфор- 
мации, и запишите эти метки в отведенных полях. 


Энн Бренсон 62 Джейми Гамиль 

я: 1/7/19 лыилон 
Даила рекоа Дама рождения: 10/9/1964 
Программ Сисилемный админисилраилор 
Не замужем, Не женат 


но есиле плане! 
Саннивейл, СА 


Е „СА 
а обвот аолёбофег@Бгеаклескрізга. 
дли со” 

; книги, МЁМЁ 
м НЕ мибо а иеа 
их 2 

к бома 

Ищекл: новая ра Ищем: друзья, женщины 


Алан Скупи 


Дата ро 1 
Инженер Ждения: 107/19 


Женаил 

Сан -Анилонио 
еее але ува ін ТХс 

Киа роза. сот 
Т Увлечения: ролевые игры 


У, "Рограммированце 
Ищет: ницего 


Анджелина Мендоса 
ама рождения: 

19/8/1979 

О Сисилемный 

админисирамор 


ае ое оар \ Замужем 


\ Сан-Франциско, СА 
аһдеїлаёѕъагЬиг2со№ее.сом^ 


^\ Увлечения: иледилр» ланце! 
Ищет: новая работа , 


ноя: 
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г. ВОЗЬМИ в руку карандаш 


№ 2шение Перед вами несколько карточек из каталога Грега. Найдите 
ж, сходные данные, собранные Грегом о каждом человеке. При- 
свойте таким данным метку, описывающую категорию инфор- 
мации, и запишите эти метки в отведенных полях. За 
Имя 
фамилия К аилегории, 
\ коилорые мы 
5н нсон е" определим, 
Дам ождения: 1/7/ 922. Джейми ильилон —> РУ р ил исмоль - 
амла р Еа Дарла рождения: 10/9/1964. Ч д 
Программ Системный админисилраилор зоваилься для 


Силдилус (2 Не замужем, 
Маунилин -Вею, СА 
але @боди4$-Г-и5.С 0 


увлечения: книги» паи Р 
прогулки, домашнее ми 


абоила 


Ишеи: новая р 


Мы разделили полное 


имя на имя и фамилию. 


Такое деление позднее 


но есиль планы 


Не женаил 


Саннивейл, СА 


аогірофлегёБбгеакиескрігга. 
соил 


Увлечения: плуризм, лиилера- 
илура 


Ишет: друзья, женщины 


Алан Скуи 
Дама 


Профессия — 2: Инженьр 2 ения: в 


циорядочения 
данных. 


пригодиился нам ири 


сорилировке данных. 


Дата рождения. 


г плеа 1 


Женаил 
Место —__ 
жиилельсилва ” Сан-Антонио, тх 
_27%0иКир@һгеакуе Кю 
- У скрі22а.соид 
лекилронная — Увлечения. 


(2) 
лочила рые игры, 


"Рограммированце 
Ищеил: Ничего 


Анджелина Мендоса 

аула рождения: 
19/8/1979 
Сисилемный администра - 
иса 


Замужем \ 
РЭРРЕРАрУ р л Грег уже записал 
ағдеіпа@ѕёагриз2соћге.сот — на своих карилочках 


по алин названия некоилорых 
каилегории: «Даила 
рождения», «УвВлече- 


ния» и «Ищет». 


Ищем: новая рабоила 


Рассматриваем данные по Категориям 


Давайте взглянем на данные с новой точки зрения. Если разрезать 
каждый листок па полоски, а затем разложить их по горизонтали, 
вот что у вас получится: 


‚ иланиы новая 
Анджелина Мендоса `уауз/л979 Системный Замужем — Сан-Франциско, СА аьле[ітаёсьонбытзсоћее сори =“ а } 


——“““" су 


Если теперь разрезать еще один листок с названиями этих категорий 
и разложить полоски над соответствующими данными, результат 
будет выглядеть примерно так: 


Имя ад А бвр ам уу Профессия и. пиана „вл В Электронная Увлечения Ищет 
Е: < слм і і почта т! | 


новая 


туар ‚рабоила 


а 
Анджелина Мендоса 14/8/1979  Сисулемный Замужем | сан-франциско, СА лпаейикабоваибиатсоНее. сол ФЛЁ 


ВИ ад миниситратчор оннар 


А вот как выглядит та же ипформация в виде ТАБЛИЦЫ из строк и столбцов. 


А я уже видел такое представление дан- 
ных в Ехсе|. Чем таблицы 501. отличаются 
от него? И что это за столбцы и строки? 


увлечения 


электреиная 
почта 
Бренсон аппіе@боагаѕ- 1-7-1962 программист Маунтин-Вью, | не замужем, 
г-иѕ.сот СА но есть 
планы 
Гамильтон Джейми доп{Бо{Вег@ 10-9-1964 системный ад- | Саннивейл, СА не женат 
Бгеакпеск министратор 
рігга.сот 


ролевые игры, 
программи- 
рование 


новая 
работа 


друзья, 
женщины 


туризм, лите- 
ратура 


Энн - 
Скуп Алан ѕоикир@ 1-7-1966 инженер Сан-Антонио, женат ролевые игры, ничего 
ргеакпеск ТХ программи- 
рігга.сот рование 
Мендоса Анджелина ападеіпа@ 19-8-1979 системный ад- Сан-Фран- замужем театр, танцы новая 
ѕќагриг2со##ее.сот министратор циско, СА работа 
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У тю базам данных 


Что такое «база данных»? 


Прежде чем переходить к подробному рассмотрению таблиц, 
строк и столбцов, давайте сделаем шаг назад и попробуем пред- 
ставить общую картину. Первая структура 501, о которой вы 
должны знать, — контейнер, в котором хранятся все ваши табли- 
цы. Она-то и называется базой данных. 


: Базой данных называется контейнер, : 
: в котором хранятся таблицы и другие : 
‚ структуры 501. для работы с ними. 


Каждый раз, когда вы выполняете поиск в Интернете, обращае- 
тесь за справкой, используете ТУ, заказываете билеты, получаете 
штраф за превышение скорости или покупаете что-нибудь в магази- 
не, необходимая информация запрашивается из базы данных. 


ту Ча+абазе 


Х 


На диаграммах и блок-схемах базы 
данных изображаются 6 виде цилиндров. 
Когда вы видииле илакое изображение, 
значиил, перед вами база данных. 
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Плейлист В Б 


| Кредит Ы" 
на образование 
| Таблица рекордов р”. 
6 Видеои2 ре 


1М0Ь 


зав Банковские счета | 


Заказ номеров 
$ 20стинице 7 


Вы и ЛИЧИО ЖР из окруУ 
жаноиАих х Вас баз данных: 


р = Телефонные счета 


Автоинспекция 


__—_ 
Кредитные Карту! 
2 Библиотека | 


са са 
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Кл под Микроскопом 


РАСА мачиле о базе 
данных как о кон- 


илеинере, 6 коило- = 


ром храниился 
информация. 


Тоже илаблица. 


И еще одна 
иладлица. 


: Информация в базе 
: данных делится 
: на таблицы. 


Посмотрим на базу данных 
через Волшебные очКи... 


Тє по базам даних 


База данных состоит из таблиц. 


Таблицей называется структура, в ко- 
торой хранятся данные, упорядочен- 
ные по столбцам и строкам. 


Помните категории из предыдущего 
примера? Каждая категория соответ- 
ствует столбцу таблицы. Например, 
столбец может содержать одно из зна- 
чений: Не женат, Женат, Разведен. 


Строка таблицы содержит всю инфор- 
мацию об одном объекте таблицы. 

В новой таблице Грега строка содер- 
жит полное описание одного челове- 
ка. Например, в одной строке могут 
храниться следующие данные: Джон, 
Джексон, не женат, писатель, 

1) ФЬоагаѕ-г-иѕ.сот. 


СТ Ар таблицей 


[аже Вы найдетпе несколько картрочек ч траёлчиу, Раша 
задача — предстраВитрь себя на Местре Частично заполнен — 
Ной трабЛиЦы, запоЛнитрь пустрые Местра и До— 
стричь просВетрЛения, Когда Вы спраВитресь 

с упражненцем, переВернитре страницу и про— 
верьтре, УдаЛось Ли Вам ДостриЧь духоВноГо 


единения с таблицей, 


саифигх Со ее 


25/4 
Риисаис Ролик с вареноем 
Е а 
ы 7:45 
с вареньем почили идеалено 
8:56 
Жирновдилы 


ам илаблицы 


Присвойиле лол 
‚нные имена. 


№ тю базам данных 


8 > 


Риисаи‹ Ропик 
7 


24/4 


Мало варенья 
22:55 


с вареньем 


с вареньем 
вчерашние, но вкусные 
© 

Кғіѕру Кіма 

26/4 


21:59 


мало варенья 


дальше » 47 


№ тю базам данных 


(ТАШ) залей, (ое 
По содержимому карилочек 


Вы должны быЛи предстоаВитоь себя на Местое поняилно, чило речь ид 
идеил 
ЧастпиЧно запоЛненной трабЛиЦы и запоЛнитрь о пончиках с ва реньем. 


пустые Местра. 


= а 


| Ѕ+аерих2. ани аа ж почили 
= идеально 


[Рипсаи Роли | ей жирноваилы 


Если Ваши имена 
силолбиов не совпали Киру Кімд 4:59 рил | 4/26 виераилние, 
с нашими — ничего но Вкусные 


сипрашного. | Риисди® Ролиё | 10:55 рил | 4/24 | 7 | маловаренья | 


В базах данных хранится логически сВязанная информация 


Все таблицы в базе данных должны быть так или иначе свя- 

заны между собой. Например, база данных с информацией База данных с именем 

о съеденных пончиках может состоять из следующих таблиц: иу иас! сосилои и 
из илрех илаблиц. 


^ “ту зпаск$ 222° 


мз нате“: 
ваний 


Имена дазы данных и илаблии 
обычно залисываются сим - 
волами нижнего регисилра. 


аналарын 
је11у_ доџдћлобв 
Гана Г онен 
Ели Ста 
| зас 
ткн 


Таблица с инфор - 
мацией о пончиках 


с вареньем. 


Таблица с инфор- 
мацией о пончи- 
ках с глазурею. 


Ра 


Тадлица с инфор- 
мацией о других 
блюдах. 
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р. № то базам данных 
|аёлиць: Под УвелиЧитоеЛьнымМ сатекЛомМ 


: Столбец — фрагмент данных, хранящихся в таблице. Стро- 
: ка (или запись) — набор столбцов, описывающих атрибуты 
: одного объекта. Столбцы и строки образуют таблицу. 


Перед вами пример таблицы для хранения данных адрес- 
ной книги. Столбцы также часто называются полями — 
эти два термина означают одно и то же. Кроме того, тер- 
мины строка и запись тоже считаются синонимами. 


Силолбиы 
а 00 Ма. № 
| Яга? пете | 151 поте | айдгезз | «у | зе | М мот | 


Джо данные данные данные данные 
|. э [кн [ ные | донные [ даные | пенье | 
(записи). 
м Мэри Моррис данные данные данные 


х. 
Одъединяем Сиполдиы со сил 


оками — 
и получаем иладлицц. я 


> 
У 


Гава ешь [азан [ева | к [ вы [мы | 


рты Джонс данные данные данные данные 
— Моррис данные данные данные данные 
Грин данные данные данные данные 
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Выходит, данные с моих карточек 
можно преобразовать в таблицу? 


Бини чаа 


Вот именно. Сначала информация о каждом 
человеке разделяется на категории. 

Категории становятся столбцами. Каждая карточка 
преобразуется в запись. Вы можете взять всю информа- 
цию с карточек и преобразовать ее в таблицу. 


Каиегории (с. 45). 
"А8 У ЎҚ 79 


Имя Профе, Место Увле Ищем 
Фамилия ь Дала а сан 7 Силаилус Жиуиельсилва Ё Элекилронная ка! 
: нет 1А рождения р рна, течан у оцудд 
ешинин д ьиньый 
Анйжелина иледилр, иланиы В овая 


Мендоса 14/8/1979 Системный Замужем Сан-Франциско, СА дидела@свагиясо Нее, абома 


нна ринит 


Ҳ Данные одной ка 
его ии Ю- 
- ь вы знавиле, Чило Катер илочки одразуюил 

т вание силолдиа ми силроку. 

назе! 


0. Бс 
| Газ? пете | Нев! пате | _ етай | Ынһдеу | рғоѓезајоп | Іосейоп | мошз | інеғөвів | 


Бренсон Энн аппіе@боагаѕ- | 1-7-1962 Программист Маунтин - Не заму- | Книги, пешие 
г-иѕ.Сот Вью, СА жем, но прогулки, до- 
есть планы | машнее пиво 
Гамильтон Джейми допіроћег@ | 10-9-1966 Системный Саннивейл, | Не женат | Туризм, лите- | Друзья, 
уаһоо.сот администратор СА ратура женщины 
Алан #ргоѕе@ 2-12-1975 Инженер Сан- Женат Ролевые игры Ничего 
уаһоо.сот Антонио, ТХ 
Мендоса Анджелина апде!79@ 19-8-1979 Системный Сан-Фран- Замужем Театр, танцы 
дтай.сот администратор | циско, СА 
— И Чило данные каждой 


м карилочки Размещаюился 


6 одной силроке, которая 


илакже можеил 
назывдил 
записью. во 


Наконец-то. Но как 
я буду создавать 
свою таблицу? 
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Перед вами несколько баз данных и таблиц. Подумайте, какие категории 
пр ажнение данных вы бы включили в каждую таблицу. 


1ірғгагу аь 
=. ш База данных библиоилекк. 


—_ 
Е рь 
———— } Боокз (книги): а. 


Боокз 
| (посетители): 
13Ьгагу_рабгоп | 
рии...) 
ЕРНИН рапк ар 


База данных банка. Е 


созёошег 1пЁо 


(клиенты) : Сиз ёотег іп ғо 
Ъапк_ассоппе 
(счета): 

рапк ассоопіё 


оп1іпеѕіоге аЬ | ша | 


ы а < База данных инилернеил -магазина. 
ргойосє по 


ргоаисЕ_ 1пЕо 
(товары) : 


5һорріпа сах 


зһорріпд сагі 
(корзина): 


51 


Перед вами несколько баз данных и таблиц. Подумайте, какие категории 
пр ажнение данных вы бы включили в каждую таблицу. 


116Ьгагу аь 
. ря ш База данных библиоилеки. 
сга Е: 
аа Ъоокз (книги): название, авилор, цена, 

| БооК$ ‘номер по ка р Ч 
=== 
і 1іргагу раёгоп 
: (посетители): имя, фамилия, адрес _ 


13Ъгагу рабгоп 


нонат ТЫ арыта а к очетни: 
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данных банка. 
База чә 2 


сиѕіотег іпЁёо 


| Е. 
О ИР: СЕ : 
уеавтю номер счеила Отег 1пЕо 


Ъапк ассоџп+ і 
(счета) : м 
средсилв | 
; рапк ассооџпі 
| ЕЕЕ 
оп1іпеѕіоге аЬ = 
у дания — <— База данных инилернеил -магазина. 
` ргоачс® іпёо | 
| 
і | _ ргоаосё го 
ЗЬ . | (товары): ‚название, размер, цена в 
ОРріпо с | 
ты агі А зћһорріпд сагі 
ГШ | се на 
р 
А, 


ааа, 
а 
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Командуйте! 


Запустите свою систему управления реляционной базой данных 501. (РСУБД). 
Откройте окно командной строки или графическую оболочку для работы с РСУБД. 
Наше окно терминала после запуска Му5ОГ. выглядит так: 


Ре Ед \У/паом Нер СоттапаМеВабу 


Ме1соме Ео ће 801 моп1Фог. Соптап@$ епі м1ЕВ ; ог \9. 


Туре 'Һе1р;!' ог '\һ' Ғог һе1р. Туре '\с' іо с1еах Ве БаЕЕег. 


С 


Угловая скодка — ириглашение команд- 


ной силроки. После нее Вводяился команды Проделы в именах баз дан - 
управления. ных и илаблиц 501. запрещены. 
р Вмесило них обычно использу ~ 
Прежде всего необходимо создать базу данных, в которои нился символы подчеркивания 
будут храниться таблицы с данными. а 
А 


1) Введите следующую команду для создания базы данных с именем 9гедѕ 113+. 


СВЕАТЕ РАТАВАЗЕ дгедз 115%; 


СКЕАТЕ 

РАТАВАЗЕ — ў Я 
манда. : Ге [св __ 

2 Е" б. данных иМя дазы 


р 
Б РЕ 


Ғе Еа Міпаом Нер СоттапаМеВаь 


> СВЕАТЕ ПАТАВАЅЕ агедѕ 115+; 
КА Очеку ОК, 1 ком аёҒесёеа (0.01 ѕес) 


\ 


Соодщение оил 


РСУБД иоказыба- и, Ш ................... ОИЕ 


— 


Команда долж - 
на заверщаилься 
символом <<;> 
(илочка с заия- 
илой). 


ёил, чило запрос был 
Р А вы прочитали Введение? 


успешно Выполнен. 


руьое | Мы используем Му$ОЕ для управления 


‚ остроРожНы, своими базами данных, поэтому команды 

: вашей системы управления базами дан- 
ных (СУБД) могут выглядеть немного иначе. Инструкции 
по установке Му$СЕЁ на сервере приведены в приложении ІІ. 
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Теперь необходимо приказать РСУБД использовать 


только что созданную базу данных: 


О5Е дгедѕ 115+; 


Телерь все последующие 


= — операции будуил выпол- 


няилься с дазой данных 


29А) 3635.115! 


Ее ЕЗИ Міпаом Неір УЗЕМ 


> 05Е дкеаз 113%; 


РабаБазе сҺапдеа 


. 
, Зачем создавать базу данных, 
если таблица всего одна? 


(} Язык 501 требует, чтобы все таблицы 
находились в базах данных. Для такого 
требования имеются веские причины. 

В частности ЗЕ позволяет управлять до- 
ступом к таблицам со стороны нескольких 
пользователей. Предоставить или запре- 
тить доступ ко всей базе данных обычно 
проще, чем управлять доступом для 
каждой из множества таблиц. 


: Команда СВЕАТЕ РАТАВАЅЕ за- 
писана символами верхнего регистра. 
Это обязательно? 


(} В некоторых системах ключевые 
слова должны записываться в верхнем 
регистре, но в 5СЕ регистр игнорируется. 
Это означает, что записывать команды 

в верхнем регистре не обязательно, но 
это считается признаком хорошего стиля. 
Взгляните на только что введенную нами 
команду: 

СВЕАТЕ РАТАВАЗЕ дгедѕ 115%; 
Регистр символов позволяет легко отде- 
лить команду (СВЕАТЕ РАТАВАЅЕ) 
от имени базы данных (дгедэ 1ізі). 
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частпо 
адаВваеМые 


Воу сь 


: Как выбираются имена баз данных, 
таблиц и столбцов? 


(} Старайтесь выбирать содержатель- 
ные имена. Иногда для этого приходится 
строить имя из нескольких слов. Пробелы 
в именах запрещены, но они обычно 
заменяются символами подчеркивания. 
Несколько распространенных вариантов: 


дгедѕ 1іѕі 
4ге9$11$6 
Сгедѕ1іѕі 
дгедзх1ізі 


: А если я предпочитаю имя 
«9гед$$ без подчеркиваний? 


() Нет проблем. Здесь важно вы- 

брать один стиль и придерживаться его. 
Если вы присвоили базе данных имя 
дгедѕі ізі без подчеркиваний, а второе 
слово начинается с буквы верхнего 
регистра, применяйте эту схему ко всем 
таблицам базы данных — например, 
назовите другую таблицу туСопёасіѕ, 
чтобы не нарушать выбранную схему. 


‚ Разве не правильнее было бы на- 
звать базу данных дгед'з_И${? Почему 
в имени нет апострофа? 


(} Апострофы имеют особый смысл 

в 01. Теоретически апостроф можно 
включить в имя таблицы, но проще обой- 
тись без него. 


› Я также заметил символ «;» в кон- 
це команды СВЕАТЕ РАТАВАЅЕ. Для 
чего он нужен? 


(} Символ «;» является признаком конца 
команды. 


Регистр символов 
и подчеркивания 
упрощают работу 
программиета 
(хотя для ЭОГ, 
они не нужны! ). 


Создание таблицы: Команда СКЕАТЕ ТАВІЕ 


Давайте посмотрим, как создаются 
таблицы, на примере данных с описа- 
ниями пончиков. Предположим, вы 
часто забываете, что означает то или доодћпоё 1іѕі 
иное название. Просто создайте та- Е 


блицу, и вам не придется ничего запо- Чоодћпо!_пате Чоодћтої Туре 
минать. Введите приведенную ниже Віообеггу с начинкой 
команду в консольном окне, а потом ратат сае 
нажмите КЕТОВМ, чтобы РСУБД вы- 


полнила эту команду. 


П 
Имя илаблииы Росмо наж, 
- АА; 
команда ве ОРА = залисываеился ЕТИКА, лае 
оздания улаблицо Ер 6 нижнем реги- бАЖИМЬ команд лро 
с. дили 6 АС" Д силре и можем оц Сирок _ у но 
Ор егиси^Р сиМ®о содержаиль 09деил проще р лак вам 
Ое в дче драильея | Разо - 
симболе модчер СЯ 6 ее ея 
Лев кивания. сисе. Нилак_ 
ебая круглая скобка Е И Ы 
оилкрываеил список По Бы / 
С я 
сллолдцов 6 созда- СВЕАТЕ ТАВЬЕ доџдһпиё 113% <,„ смолі 
Ка т азделяюился 
Е; ( Е ир: 
Имя первого Р 
силолбца млаблице!. з бӢоцдћпиє пате УАВСНАВ (10), 


——> аоцдһћпиё буре УАВСНАБ (6) 


——— 


); т 
е — 


Правая круглая А эило ТИП ДАННЫХ. В силолбиах липа 


скобка заверилаеил Символ <;> УАВСНАК (МАКа Ее СНАКасёек) храниился 
список силолбцов. сообщаел РСУБД  илексиловая информация. Запись (©) озна - 


о завершении пасу, чило длина илексила не превыилаеи^ 
команды. © символов. 


ЭЙ, а как же я? Как создать таблицу для 
моей базы данных дгедѕ_|і512 


Создание более сложных таблиц 


Помните столбцы таблицы Грега? Мы записали 
[аѕё пате 


их на карточке. Эта информация понадобится 
вам для построения команды СВЕАТЕ ТАВІЕ. Вуѕё паиле 


ёмаг 
Ниву 
Команда СВЕАТЕ ТАВЕЕ РР" Робат 
иревраилиил эило... осаНои 
5Фаёис 


(ибегесёс 


5ееКиа 


‚0 мозговой 
^7 ШТУРМ 


еж 
Найдите два важных отличия между именами столбцов 


на карточке и в таблице. Почему они важны? 
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ѕзеекіп9 


Посмотрите, Как просто пишется Код $01 


Вы уже зпаесте, что для создания таблицы данные необхо- 
димо разбить на категории. Затем вы подбираете подхо- 
дящий тип данных и длину каждого столбца. После этого 
паписать код 501. будет совсем несложно. 


„ Возьми в руку карандаш 


к 


> Слева записан код команды СКЕАТЕ ТАВІЕ для новой базы 


данных Грега. Попробуйте догадаться, что делает каждая строка 
команды СКЕАТЕ ТАВІЕ. Также запишите пример данных, 
которые будут храниться в каждом столбце. 


СВЕАТЕ ТАВЬЕ ту сопфас®з 

( 
1азё пате УАВСНАВ (30), 
Ғігѕі пате УАВСНАВ (20), 
ета11 УАВСНАВ (50), 
Ь1гЕРаау РАТЕ, 
ргоѓеѕѕіоп УАВСНАВ (50), 
Іосаіоп УАВСНАК (50), 
ѕсацѕ УАВСНАК (20), 
іпёегеѕіѕ УАКБСНАВ (100), 


ѕеекіпд УАВСНАВ (100) 


„ возьми в руку карандаш 
*... Решение 


е. 


СВЕАТЕ ТАВІЕ пу сопіасізѕ 
( 


Ниже приведены описания каждой строки команды СВЕАТЕ 
ТАВІЕ и примеры данных для каждого типа столбца. 


Создаеил илаблииц с именем ‘илу_соифасес ей 
Начинаеил список силолдцов 255565 


Добавляеил силолдец с именем "аѕё маиле", 
Влмеиданидиц до 50 символов 


Добавляеил силолдец с именем 'Ии$Е_ "Джиллиан! 
лаиле', Влещаидий до 20 символов 


Добавляеил силолдеи с именем ‘ела’, [ аидегзок@ 
Вмещаюидий до 50 символов а соил! 


ЕС силолдец с именем 'бтеЕлдау, {' 1980-05-09 

8 коилором хранится даила 
Додавляеил силолдеи с именем ‘риоЕезятои’, | 'Писаилель' 
Вмсиданоиций до 50 символов 
Добавляеил силолдец с именем оса ой", 
бмешањюищий до 50 символов 


Іаѕі пате УАРСНАКБ (30), 


Ғігѕё пате УАВСНАВ (20), 


ета11 УАВСНАВ (50), 


Ь1гЕРаау РАТЕ, 


ргоҒеѕѕіоп УАВСНАВ (50), 


1осаёіоп УАВСНАБК (50), 


Добавлягил силолбец с именем '5фафи$’, 
блле дающий до 20 символов 


Добавлягил силолдец с именем ‘ифегезёя', |' Каяк, илеррарицм' 
8меилающий до 100 символов 

Додаёлясил силолдец с именем 'ѕеекімд', |' Друзья! 

в мемаюий до 100 символов 


ѕёаёиѕ УАВСНАВ (20), 


іпегеѕёѕ УАВСНАВ (100), 


ѕеекіпс УАВСНАВ (100) 


й Наконец-то создаем таблицу ту _соп+асїс 


[ Теперь вы точно знаете, что делает каждая строка, 

№ и можете ввести команду СВЕАТЕ ТАВІЕ для созда- 

У ния таблицы. Команду можно вводить по строкам, 
копируя ее из приведенного выше определения. 


А можно ввести все в одной длинной строке: 


ЦРАТЕ ТАВЬЕ ту сопбасбе (1а8с паве УААСНАЕ (30), Ё1г8Е пата УААСИАВ (20), ава! 1 УААСНАВ (50), Ьігећдау РАТЕ, ргобќеваіоп УАВСНАВ (50), 1осаёіоп УААСНАВ (50), ааіџа УАРСВАЙ (20), {піагевба УАЮСИАА (100), еек 1 


Какой бы способ вы ни выбрали, прежде чем нажимать ` Поверьте, эило ила самая 
ВЕТОКМ после «;», убедитесь в том, что вы не пропустили команда. Просило мы записали 
ни одного символа: ее ОЧЕНЬ МЕЛКИМ шриф- 
1азЕ пате УАВСНАБ (3) — совсем не то же самое, что илом, чилобы она помесилилась 
1аѕіпате УАВСНАВ (30)! на силраниие! 
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Таблица зотоВа 


> СВЕАТЕ ТАВЬЕ ту сопіасіѕ 
=> ( 


1азЕ пате УАБСНАВ (30), 
Ғігѕё паме УАВСНАВ (20), 
етаз1 УАВСНАВ (50), 
Ъ1кЕРаау РАТЕ, 


ргоЁезз1оп УАВСНАВ (50), 
Обраилите АРТЕ Іосаёіоп УАБСНАВ (50), 
мание: нажаилие 095 УАВСНАК (20), 
РЕТОВМ после іпіегеѕіѕ УАВСНАБК (100), 
символа <<;» за - зеекапа УАВСНАБ (100) 
вВершаеил ввод > ); 


команды и ири- “> Оџегу ОК, 0 гомз аЁЁескеЯ (0.07 зес) 
казываеил РСУБД 


Вылолнииль ее. 


И что же, все данные должны храниться 
в столбцах УАРСНАВ или ОАТЕ? 


пваа м“ 


Вообще-то вам понадобится еще несколько типов 
для других видов данных — например для чисел. 


Предположим, в нашу таблицу добавляется столбец с ценой 
пончиков. Хранить числовые данные в столбце УАВСНАК 
неудобно. Значения таких столбцов интерпретируются как 
текст, и с ними нельзя будет выполнять математические опе- 
рации. Однако существуют и другие типы данных, с которы- 
ми мы пока не сталкивались... 


о мозговой 
^^ ШТУРМ 
Прежде чем двигаться дальше, приведите пару 


примеров данных, для хранения которых недоста- 
ТОЧНО типов УАВСНАВ или РАТЕ. 
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ЗнакометВо с типами данных 


Перед вами еще несколько полезных типов данных. Их рабо- 
та — хранить ваши данные без искажения. С УАВСНАВ и РАТЕ 
вы уже знакомы; пора познакомиться с остальными. 


ТЕК). 

СНАЁ (или самия илребЧ- ІМТ (или ІМТЕСЕВ) счиила - 

Сиро?" нр данные име еил, чило числа должны быиль 

бил, ЧИЛ о! ванною длину целыми, но не боиился оилри - 

ли фиксиро цаилельных значений. 

Мы сами не Зи 

РЕС (или реСіІМА) В: ге г молй. А 
Обеслечиваеи^ кране * 7 Чайно заџлесался ^ 
ние чисел с заданно 35 75 
рлочносилоню: а % 


Зовеился РАТЕТІМЕ 
или ТІМЕЅТАМР 

6 зависимосили 

оил РСУБД. Хра- 

нийл даилу и ремя 7 
Ее родсилвенник 

ТІМЕ рабоилаеил 
илолько с Временем 

дез даилы. 


храниил илек- 7 
силовые данные длиной 


до 255 символов. Оил" 


личаеися НИ 
легко присиосабли аё 
ся к леременноИ длине 


данных. 


МАВСНАК 
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ВОВ рабоилаеил 
с большими дло- 
ками млексиловых 
данных. 


РАТЕ храниил 
даилы — но не об- 
Ращаеил Внимания 
на Время. 


В вашей РСУБД могут исполь- 
зоваться другие имена типов! 


|7 дье 


А осторожны ! 


К сожалению, общепринятой си- 
стемы имен типов не существует. 
В вашей конкретной РСУБД некоторые типы могут 
называться по-другому. За информацией о правильных 
именах обращайтесь к документации РСУБД. 


Выберите наиболес подходящий тип данных для каждого Количесилво цифр 8 целой 


столбца... А заодно заполните другие недостающие данные. а дробной часили. м6 


[биз отобца_| Описание [м [мощи тп 


Цена продаваемого 5678.39 рЕс(6,2) и 
товара 


От 5 до 10 символов 


Атомный вес элемента 
(с точностью до 6 цифр) 


аіотіс 
меіаћі 


Джо, я на собрании акционеров. В демоверсии 
по экрану летают резиновые утки. Это что, шут- 
ка такая? На премию можешь не рассчитывать... 


Болыной блок текста 
(длиннее 255 символов} 


соштепе $ 


ачапёіїу 


3.755 
Неаа Ея 501, 


Ставка налога 


фах гасе 


роок +Е1Е1е Название книги 


депаек Один символ — М или Ж 


рћһопе 
питрег 


Десять цифр без знаков 
препинания 


2105552367 


Двухсимвольное сокра- 
щение штата 


ТХ, СА 


Дата рождения 


11/22/2006 РАТЕ 


аппіхегзагу 


затеѕ моп Количество побед в игре 


тееёіпа 
іме 


10:30 а.т. 4/12 /2020 


Время (и день) встречи 


Частро 
о залаВаеМые 


Вот сы 


}: Почему мы не храним все тексто- доступные для УАВСНАВ и СНАБ (но об |: Это все? Других типов нет? 
ные данные в столбцах типа ВІОВ? этом позднее). 


(} Есть, но эти типы самые важные. 


() По соображениям эффективности. | а Конкретный набор поддерживаемых 
Столбец УАВСНАК или СНАВ имеет фик- ‚ Зачем нужны разные числовые типов данных также зависит от РСУБД, 
бированный размер, не более 256 сим- типы ІМТ и рЕС? поэтому за дополнительной информацией 
полов. Столбец ВІОВ занимает намного следует обращаться к документации. Так- 
больше памяти. С увеличением объема (} Опять же по соображениям эффек- же рекомендуем книгу «З@ іп а №иіѕћеї» 
билы данных может кончиться место тивности. Оптимальный выбор типа (О'Кейћу) — это отличный справочник, 

ни жестком диске. Кроме того, со значе- данных для каждого столбца таблицы в котором описаны основные различия 
ниими ВЕОВ нельзя выполнять неко- уменьшает ее размер и ускоряет работу между разными РСУБД. 

оро важные строковые операции, с данными. 
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+ кто й Ч, 
кто и У АЕААЕТ? В индексе можеил быль 
е меньме 10 цифр, поэил 
мы использовали МАРСН 
для экономии месила. Та! 
можно было выдраиль иль 
СНАК с фиксированной 
длиной значения. 


Наиболее подходящий тип 


нЕ п 5678.39 рЕС(5,9) 


Выберите наиболее подходящий тип данных для каждого 
столбца... А заодно заполните другие недостающие данные. 


ргісе 


2ір соде 90240-00010 МАВСНАК(10) «—— 


От 5 до 10 символов 


‚Атомный вес элемента 
(с точностью до 6 цифр) 


аёоміс 
меісћё 


4.002602 РЕС(10, ё) 


Джо, я на собрании акционеров. В демо- 
версии по экрану летают резиновые 
утки. Это что, шутка такая? На премию 
можешь не рассчитывать... 


еек | о НТ 

ачапііёу 254 

товара на складе 

сах габе Ставка налога З; [3.755 РЕС(Ч, 2) 


Неаа Еїгѕг 501. УАКСНАК(50) 
СНАХ (1) 


Большой блок текста 
(более 255 символов) 


ВОВ 


соптепё $ 


роок (1Е1е | Название книги 


депаег Один символ — М или Ж 


рһопе 
попрег 


Десять цифр без знаков 
препинания 


2105552367 


СНАВ(10) < 


Двухсимвольное сокра- 
щение штата 


ѕісасбе ТХ, СА 


СНАК(2) 


287117006 


15 ІМТ 


10:30 4/12 /2020 РАТЕТІМЕ 


аппіуегѕагу | Дата рождения 


сапеѕ моп Количество побед в игре 


пееїіпа 
іме 


Время (и день) встречи 


А Телефонный номер име 
Тил ТІМЕЅТАМР обычно исполь- вил фиксированную дли 
зцеился для сохранения илекущего ну. И мы рассматри - 
времени. Тим РАТЕТІМЕ лучше ваем его как силроки 
подходиил для будущих собыилий. илексила, поилому чило 


с номером не нужно вь 
иолнямь маилемаиличе 
ские вычисления. 


62 глава 1 


МОМЕНТЫ Әу 


а Прежде чем создавать таблицу, разбейте дан- ш Таблицы создаются командой СВЕАТЕ ТАВІЕ 
ные на категории. Уделите особое внимание с указанием имен столбцов и их типов данных. 


выбору типа каждого столбца. 
Ру ЖД Н в Основные типы данных столбцов: СНАВ, 


ш Создайте базу данных, в которой будут хра- УАВСНАВ, ВГОВ, ІМТ, рЕС, РАТЕ и РАТЕТТМЕ. 
ниться все ваши таблицы, командой СВЕАТЕ Каждый тип устанавливает свои ограничения 
РАТАВАЗЕ. для хранящихся в нем данных. 


ж Используйте команду 95Е РАТАВАЗЕ, чтобы 
получить доступ к базе данных и перейти 
к созданию таблиц. 


Минутку, а где таблица, котору я только что 
создала в базе данных дгед$_!151? Хочу убе- 
диться в том, что все было сделано верно. 


Отличная мысль, проверять себя необходимо. 


Чтобы посмотреть, как выглядит созданная вами таблица 
пу _сопфас®з, воспользуйтесь командой рЕЅС для выво- 
да ее описания: 


РЕЗС шу сопіасіѕ; 
„> м = 


РЕЗС — сокраи 
, ащение оил РЕЗ 
(вывесили описание) НІВЕ 


Попробуйте выполнить эту команду. 


Ее Еди \У/пдом Нер Оеѕсті 


> рЕЅС ту сопіасіѕ; 


айь а № 


Описание таблицы 
На эми аитрибуилы пока 


Результат выполнения команды РЕЗС не обращайиле ЕЯ 
выглядит примерно так: вскоре мы Вернемся к я 
у им. 


в 


Ее ат Мусо Нер ево у ааа ЕЕН ССА СА а 
> РЕЗС ту сопбас®$; 


: ( р + 
№11 | Кеу РеҒаџі+ | Ехега | 


и ЗЕ 2 


—---+ 

уагсһаг (30) 1 | 

уагсћаг (20) | 

уагсваг (50) | 

аа+е | 

ргоёезз1оп уагсъахг (50) | 

1осаёіоп уагсћаг (50) 1 

уахсваг (20) | | 

| іпіесеѕіѕ уагсћаг (100) } 

| ѕзеекіпд уагссћаг (100) | 

+------------ + 
9 комѕ іп зеё (0.07 ѕес) 


Я забыл включить 

в таблицу один важ- 
ный столбец. Это еще 
не поздно сделать? 


о мозговой 
СО?ШТУРМ 


А что думаете об этом вы? Какие про- 
блемы могут возникнуть при добавле- 


нии нового столбца? 
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Ма Гниы с КодамМи 


Код создания базы данных и таблицы с новым столбцом депаег полностью 
перепутаны. Сможете ли вы расставить фрагменты в правильном порядке? 
Некоторые круглые скобки и символы «;» упали на пол. Они слишком малы, 
чтобы их подбирать — добавьте их по своему усмотрению! 


11 ЧААСНАВ (50) 
ЬігеҺаау РАТЕ 


ОЕ 9гедз 1із+ 


ігзё пате УАВСНАВ (20) 


азё папе \УАВСНАВ (30) 


1пфегез+з УАВСНАР (100) 


зееК1лд УАВСНАВ (100) 


экаказ УАВСНАА (20) 


РгоЕезз1оп УАВСНАВ (50) 


1оса+іоп УАВСНАН (50) 


ТЕ ТАВІЕ ту сопбассѕ 
Зепдег СНАВ (1) 


Когда работа будет закончена, попробуйте ввести новую 
команду СКЕАТЕ ТАВІЕ в консоли $01 для создания 
таблицы с новым столбцом депдег! 
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Маг»: с Кодами 


Вы должны были восстановить 


КЕАТЕ РАТАВАЗЕ гесе 11вЕ 


Ж 
код создания базы данных / ОЗЕ дгеда 115: 
и таблицы с новым 9“45 | уже ны 
столбцом депаег. сущесилвцеил. СВЕАТЕ ТАВІЕ шү сопбасіз 6 


Воссилановленны 
ы. Проверьиле с 
и Чиилайиле даль 


й код коман - 1азе папе УАВСНАВ (20), 


ғігзі пате УАВСНАВ (30), 
иде... — ! 


Ь ігЕҺдау РАТЕ 


. 
р 


депаег СНАВ (1), - 


РгоҒезѕзѕіоп УАВСНАЕ (50) 


Нельзя заново создать 
существующую таблицу 
или базу данных! 

А Ве помлыилались Ввесили команду 


ГРЕАТЕ ТАВЬЕ? Тогда вы, наверное, 


чило команЗа из эилого 


1осаіоп УАВСНАВ (50) 


| 


іпёегеѕзёѕ УАВСНАВ (100) , @ 


уже знаеиле 

5 ` 

ниражнения не позболинА 2 
5 ў? А П 

новом силслдёц. 


у > 
зиаиле 


зееК1п9 УАВСНАВ ( 100) 


Если вы ВВели команди 6 сВоей 
консоли, Верояилно, резульилаил 
выглядел примерно илак: 


НИТ: РЗС а И иле би 
> СКЕАТЕ ТАВЬЕ му сопфасе$ 
=> ( 
1азЕ пате УАРСНАК (30), 
Ғігѕ пате УАВСНАК (20), 


Вос етаі1 \АВСНАВ (50), 
Новый 

силолбец деп4ег СНАБ (1), 
делдек. ъігіһаау АТБ, 


ргоѓеѕѕіоп УАБВСНАК (50), 
1осаёіоп УАВБСНАБВ (50), 
зЕабиз УАБСНАВ (20), 
іпегеѕёѕ УАРСНАБ (100), 
ѕеекіпд УАВСНАБ (100) 


Ой! Получаем со ~ 
общение об ошибке. 
Похоже, младлица 
не создалась. М —> ); 


ЕВВОВ 1050 (42501): ТаБ1е 'пу сопбасіѕ' а1хеаЧу ехіѕіѕ 
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дада 


: Почему в упражнении «Развлечения с магнитами» 
я получаю ошибку? 


() Нельзя создать заново уже существующую таблицу. 

И после того как база данных будет создана, ее не нужно 
создавать повторно. Еще одна часто встречающаяся ошиб- 
ка — пропущенный завершитель «;». Также проверьте, нет 
ли опечаток в ключевых словах ОЕ. 


ђ Почему после определения столбца «зееКтд 
'АВСНАВ(100)» нет запятой, как у других столбцов? 


® А 

() Сразу за определением «зееКтд» следует закрывающая 
круглая скобка. Она сообщает РСУБД о том, что список за- 
вершен, поэтому запятая здесь не нужна. 


ВаеМые 


Вопросы 


Так команду СВЕАТЕ ТАВІЕ придется 
набирать повторно? Если бы команды 5091 мож- 
но было вводить в текстовом редакторе (скажем, 
Блокнот или Тех1Еа!), это сэкономило бы нам 
немало времени и сил. 


‚ Можно ли добавить в таблицу забытый столбец или 
все придется делать заново? 


() Придется делать заново, но прежде чем создавать та- 
блицу с добавленным столбцом депаег, необходимо сначала 
удалить старую таблицу. Так как в таблице пока нет данных, 
просто удалите старую таблицу и начните заново. 


: А если у меня есть таблица с данными и в нее нужно 
добавить столбец? Можно ли сделать это без удаления 
всей таблицы и повторения ввода? 


(} Хороший вопрос! Да, таблицу можно изменить без уни- 
чтожения хранящихся в ней данных. Мы еще рассмотрим 
эту возможность, а пока наша таблица пуста, проще удалить 
ее и создать заново. 


Очень правильная мысль. Мы рекомендуем 
почаще использовать текстовый редактор 

во время чтения книги. 

Это позволит вам копировать и вставлять команды 

в консоли ОГ, и вам не придется вводить всю команду 
заново. Кроме того, вы можете копировать и редактиро- 
вать старые команды 501 для создания новых команд. 
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Долой старые таблицы! 


1) Уничтожить старую таблицу куда проще, чем 
создать новую. Введите простую команду: 


Команда удаления и имя идаляе мой 
иладлицы ке 


а? ( уладлице!. 


"== И не задудемле 


рвоОр ТАВТЕ му _ сопасіѕ; 7 © `заверииилель <;>». 


Рфе Еа \МУ/Упдом Нер ВуеВуеТаЫе 


> ОВОР ТАВІЕ пу сопфасез; 


Оцегу ОК, 0 гомз аЕЕесееа (0.12 зес) 


Команда ОВОР ТАВІЕ работает независимо от 
того, есть в таблице данные или нет, поэтому Команда р КОГ 
использовать ее следует ОЧЕНЬ ВНИМАТЕЛЬ- 
НО. Удаленная таблица пропадает навсегда вме- ТАВІЕ удаляет 


сте со всеми данными, которые в ней были. 


таблицу со веел 
@ Теперь можно ввести новую команду СВЕАТЕ ТАВІЕ: данными! 


Ее Еа \У/Лпаом Нер $иссез$ 
> СВЕАТЕ ТАВШЕ му сопёасіѕ 
=> ( 

Іаѕё пате УАВСНАБВ (30), 
Ғігѕб пате УАВСНАВ (20), 
етаі1 УАВСНАБВ (50), 
депдег СНАК (1), 
Ъ1еЕВаау РАТЕ, 


ргоҒеѕѕіоп УАВСНАК (50), 
1оса&1оп УАВСНАВ (50), 
з$афаз УАБСНАБВ (20), 
іпёегеѕіз УАВСНАК (100), 
ѕеекіпа УАВСНАБ (100) 


На эмом Раз 


о 
все получилосе: 


Оцегу ОК, 0 гомз аЕЕесееа (0.05 зес) 
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Компания ключевых слов и типов данных 501, облаченных 

в маскарадные костюмы, развлекается игрой «Кто я?». Игрок 
дает подсказку, а остальные на основании сказанного им пы- 
таются угадать, кого он изображает. Будем считать, что игроки 
всегда говорят правду о себе. Если сказанное ими может 
относиться сразу к нескольким персонажам, перечислите всех, 
к кому может относиться их высказывание. Заполните пропуски 
справа именами одного или нескольких участников. 


Сегодняшние участники: 


СКЕАТЕ БАТАВАЗЕ, УЕ ОАТАВАЅЕ, СКЕАТЕ ТАВІЕ, ОЕЗС, 
РКОР ТАВІЕ, СНАК, УАКСНАК, ВІОВ, РАТЕ, ОАТЕТІМЕ, 
ОЕС, МТ 


Поможем с хранением чисел. 

Занимаюсь устранением нежелательных таблиц. 
Специализируюсь на вопросах Да/Нет. 

Помогу запомнить день рождения знакомого. 

Во мне хранятся все таблицы. 

Числа — это хорошо, но я ненавижу дроби. 
Люблю длинные, подробные объяснения. 

Место для хранения ВСЕГО. 


Без меня таблица не могла бы существовать. 


Точно знаю, когда вам нужно явиться к врачу на следующей неделе. 


Сохранить денежную сумму? Без проблем. 
Вывожу описание формата таблицы. 


Без нас вы вообще не сможете создать таблицу. 


Цмя 


дальше › 


(зовет на с, 86. 
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Є Д под МикроскопеМ 


Ладно, моя таблица готова. И как 
теперь перенести данные с кар- 
точек в таблицу? 


Для добавления данных В таблицу 
используется Команда ІМЅЗЕКТ. 


На приведенной ниже схеме показано, что делает каждая 
из частей команды. Значения во второй группе скобок 
должны следовать в том же порядке, что и имена столбцов. 


Ниже приведена не реальная команда, а «заготовка» — 
условный шаблон, демонстрирующий формат команды 


ІМЅЕАТ. 
Гиисок имен силолбиов, раз- 
деленных заляилыми. Как вы Имена други 
команда начинае"^^ оо ; уже знаете, в списке Грега силолдиов (за 
ас ключевых слов (8 ёо олаблицы содержаился силолдиы с име- Илая после и 
ЕКТ МТО. А. ех Гре нами ЁүѕЁ мамле, [аб маиле, следнего сило 
р П9-Соиеасьс), вилай и ил. д. не нужна). 


АА и \, № "А 


ІМЅЕРТ ТМТО имя таблицы (столбец1, столбец2,..) 


гы ('значение1', 'значение2',...) 
Ее одно ключевое РА д 
слобо; сообщает, 


чило дальше следу - Список значений, Тексиловые данные и как 
ёил список значе - разделенных заия- бсегда заключаюился ЮРИ ВВ 
ний силолёцов. илыми. В базе дан- в апосилрофы, даже Пей = завел 
ных Грега список оилдельные символы о Ния ас 
содержиил данные (например, ‘М’. ужна). г 


С карилочек. 


ВАЖНО: значения должны следоваиль В илом 
же порядке, чило и имена силолбцов. 
екоо лоиор 
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+ 
*кто и «ч 


Прежде чем составлять команду ІМЅЕКТ, необходимо устано- 
вить соответствие между именами столбцов и значениями. 


СТОЛБЦЫ ЗНАЧЕНИЯ 

Ғігѕі пате "Друзья! 

завез 'Андерсон!' 

зееК1па '1980-05-09' 

депаег 'Писатель' 

Ь1гЕРаау "Джиллиан! 

1азЕ пате "Не замужем! 

1осабіоп 'Ж' 

іпіегеѕёз "Пало-Альто, Калифорния! 
ргоҒеѕзѕіоп 3111 апаегѕопёргеакпескрігғ2а. сот! 


"Каяк, террариум! 
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+ 
"кто и „алт 


Прежде чем составлять команду ІМЅЕКТ, необходимо устано- 
вить соответствие между именами столбцов и значениями. 


СТОЛБЦЫ ЗНАЧЕНИЯ 


Ғігзі пате "Друзья! 
Значения илила РАТЕ 
должн 

сас ЕЕ жне задаваилься 
6 определенном форма 

ео иле. За подробносилями 
одращайилесь к докумен 
. О МА НҮ ' 

зееК1пд 1980-05-09 мации РСУБД. 

депдег "Писатель! 

Ьігєћдау "Джиллиан! 


1азЕ_ пате "Не замужем! 


Не забудьиле: даже олдельные 
символы должны заключаилься 


Іосаёіоп 
8 апосилрофы. 


1пеегезЕз "Пало-Альто, СА! 
ргоѓеззіоп 


3111 апдегѕопёргеакпескріғ ға. сот! 


"Каяк, террариум! 
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Создание Команды [М$ЕКТ 


6 иер 
на силолдио 
Е ой паре скобок и раз 


68 иерб 
юился ЗВИЯ 


ечисляюился 


НЕ Нажмите КЕТОВМ перед оилкры- 


бающей скобкой — эило упросилиил 


ил ми. чиление кода В окне консоли. 


ІМЅЕКТ ІМТО ПЫЗ 


(1а5Е пате, Ғігѕі паме, ета11, депӣег, рігіһаау, 
ргоҒеѕѕіоп, Іосабіоп, ѕзіаіиѕ, іпіегеѕіѕ, 


ѕеекіпд) 


% 
Нажмииле ВЕ ТУРМ после закрыйл, ( ‘коб 
ниж <] сыцеи скооки сииска 
цоб, а поилом после ключевого слова МА! ЏЕЅ а 


УАІ. <7 код, раздиилыщ 
ЈЕЅ раздиилый на Сроки, лучше чиилаеился. 


('Андерсон', 'Джиллиан', '5111 ап4аегзоп@ 
ЬгеаКпескКр12ха.сом', 'Ж', '1980-05-09', 
'Писатель', 'Пало-Альто, СА', 'Не замужем', 


'Каяк, террариум', 'Друзья'); 


Значения силолдцов пере- а 
Числяюился во вилорой 


< олбиов МАВСНАЕ, СНА, РАТЕ 


или ВОВ заключанился 6 диосилрофе. 


паре скодок и разделя_ 
КЮился замяилылли. д 


\ 
[№ Порядок важен! 


| дътре А Порядок перечисления значений дол- 
‚осторожны! жен точно совпадать с порядком 
: перечисления столбцов. 


Попробуате"сами 


пражнение 


Мы рассмотрели один из способов добавления строк в таблицу. Попробуйте выполнить 
эту команду в РСУБД. Сначала введите ее в текстовом редакторе, чтобы вам не пришлось 
набирать весь текст заново, если вы ошибетесь при вводе. Будьте особенно внимательны 
с апострофами и запятыми. Запишите ответ РСУБД в этой строке: 
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СНАВ, МУАВСНАВ, ОАТЕ и ВЕСОВ заключа- 


ются в апострофы в командах ТМ$ЕВТ. Значит, 
для числовых значений (таких, как ВЕС и ІМТ) 


не апострофы не нужны? 


Совершенно верно. 


Ниже приведена команда ТМЗЕВТ для таблицы 
с данными о покупке пончиков. Обратите вни- 
мание: числовые значения столбцов Чохепз 

и ргісе записываются без апострофов 


Силолдец рүісе иллееил или 
РЕС(4,2}; эило означаеил, 


ЧИЛО его значения сосилоЯ/ 


из чеилырех цифр с 26 
` 9вумя 
цифрами 6 дробной часил 


ІМЅЕРТ ІМТО \Яооцдһпо+ ригсһаѕеѕ Ў 
(аопиЕ буре, ӣо2епѕ, +орріпд, ргісе) 
УАГОЕ$ 

("с вареньем', 3, '5ргапК1ез', 3.50); 


"а. РА 


Значения силолбцов дохеив 
и рисе залисываюился 
дез апосилрофов! 


Силолбец Чохеис имеейл 
илии данных (МТ. 
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Возьми в руку карандаш 


Ваша РСУБД сообщает об ошибках в командах, но эти сообщения по- 

Е рой выглядят весьма туманно. Взгляните на каждую из приведенных 
ниже команд ІМЅЕРТ. Попробуйте найти ошибку в каждой из ко- 
манд, затем введите ее и посмотрите, что скажет РСУБД. 


ІМЅЕРТ ІМТО ту _сопфасез 


(1аѕі пате, #ігзі пате, ета1], депдег, Біғердау, Ее 1осаїіоп, ѕіёаіёизѕ, 
іпёегезіз, зеекіп9) УАШЈЕЅ (' ‘лидарсои", 'Джиллиан', ')111] апдегзоп@ргеакпескрі22а.сот', 
'Ж', '1980-05-09', 'Писатель', 'Не замужем, "Каяк, террариум', 'Друзья'); 


Где ошибка? 


Что говорит РСУБД: 


ІМЅЕРВТ ІМТО пу сопбасізѕ 


(1аѕз пате, Е1гз® пате, чепдег, Ь1гЕВадау, ргоЕезз3оп, 1осаёјоп, зіаёџѕ, іпёегеѕізѕ, 
зеекіп9) УАГОЕЗ (' Андерсон', 'Джиллиан' ')111 апдегѕзоп@ргеакпескрі22а.сот', 'Ж', 
'1980-05-09', 'Писатель', 'Пало-Альто, СА' ‚ 'Не замужем', 'Каяк, террариум', 'Друзья'); 


Где ошибка? 


Что говорит РСУБД: 


ТМ5ЕВТ ІМТО шу_сопфасез 


(1азё паще, #1г3е пате, етаі1, депдег, Ьігћааү, ргоЕезз1оп, 1осаф1оп, збабсиз, 
іпёегеѕзёз, зеекіпд) УАТОЕ$ ('Андерсон', 'Джиллиан', ')11] апдегзопёргеакпескрі22а. 
сот', 'Ж', '1980-05-09', 'Писатель' 'Пало-Альто, СА', 'Не замужем', 'Каяк, рептилии’, 
'Друзья'); 


Где ошибка? 


Что говорит РСУБД: 


ТМЗЕВТ ТМТО пу сопбасізѕ 


(1азё пате, #1г3е пате, ета11, депдег, ок аау, Ргоёеззіоп, Іосаёіоп, зіёаёизѕ, 
іпбегезіз, зеекіп9) МАШЈЕЅ (' Андерсон', "Джиллиан', '5)111 апдегзопёргеакпескрі22а. 

сош', 'Ж', '1980-05-09', 'Писатель', Пало-Альто, СА’, 'Не замужем', 'Каяк, террариум’, 
' Друзья) . 


ОЕ сае АЙ ЕСЛИ На эилой команде РСУБД 
<зависнеил», попробуйте вве - 


ЕНЕ: сили апостроф и символ <<: гу 
ООН после основного кода команды. 


Эальше › 75 


Р Возьми в руку карандаш 


шение Ваша РСУБД сообщает об ошибках в командах, но эти сообщения по- 
Әқ. рой выглядят весьма туманно. Взгляните на каждую из приведенных 
ниже команд ІМЅЕРТ. Попробуйте найти ошибку в каждой из команд, 
затем введите ее и посмотрите, что скажет РСУБД. 


ІМЅЕРКТ ІМТО шу сопбас+ѕ 


(1азЕ пате, {ігѕзе паше, еша11, деп4ег, Ьігіћһдау, ргоЁезз1оп, 1осаіоп, зіаїіџиѕ, 
1пегезЕз, зеекіпд) УАГОЕ$ ('Андерсон', 'Джиллиан', '3111 апӣегѕзопёргеакпескрі22а.соп', 
'Ж', '1980-05-09', 'Писатель', 'Не замужем‘, 'Каяк, террариум', 'Друзья'); 
В первом списке есиль силолбеи |осаной, а во вило- 
Где ошибка? Нем значения [осаНои. и ром списке неил значения эилого силолбиа. 


количесилву значений (с ка 1) Для разных ошибок выдакился одинако- 

вые сообщения. Будьиле вВнимаилельны: 
ны: 

ТМЫЗЕВТ ІМТО шү сопбасёз найили олечаилку бываем очень сложно. 


(1аѕ пате, #ігзі паше, деп4ег, Ьігіћдау, ргоЁезз1оп, Іосаёіоп, збаїиз, іпёегезЕЗ; “ 

ѕеекіпд) ҮАШЈЕЅ ('Андерсон', 'Джиллиан', ']111 апдӢегѕоп@ргеакпескрі22а.сош', 'Ж', 

'1980-05-09', 'Писатель', 'Пало-Альто, СА', 'Не замужем', 'Каяк, террариум', 'Друзья'); 
На эилоил раз Все значения заданы, но иро- 


ошиб ВРА ТОХОЙ НР 4 ипушен силолбец еилай В списке силолдиов. 


силвуеил количесилву значений (строка 1). 
ТМ5ЕВТ ІМТО шу сопфасез 


(1азё паше, Е1г3е пате, еша11, деп4ег, Ъ1гЕРЗау, ргоЁезз1оп, 1осабіоп, зіаіизѕ, 
іпсегеѕёѕз, зеекіпд) ҮАШЈЕЅ ('Андер сон', 'Джиллиан', ']111 апдегзоп@Ьгеакпескр1=ха. 
сот', 'Ж', '1980-05-09', 'Писатель' 'Пало-Альто, СА', 'Не замужем', 'Каяк, рептилии', 


' О . 
Друзья'); Неил замяилой между значениями силолбиов 


22 рғоѓеѕѕіои и 1осанок. 


гае ошибка? — Пролущена запятая ЕУ: 
Что говорит РСУБД: ОШИБКА 1156 (21501): Количесилво силолдиов не соом- 


Веилсилвцеил количесилву значений (силрока 1). 


ТМЫ5ЕВТ ІМТО шу сопёасізѕ 


(1аѕзё паше, Ғігэё паше, ета11, депӣег, ЬігіҺһдау, ргоЁезз1оп, 1осабіоп, зёаіизѕ, 
іпсегезіѕ, ѕеекіпд) УАГОЕ$ ('Андерсон', 'Джиллиан', '3і11 апдӢегзоп@ргеакпескрі22а. 
сош', 'Ж', '1980-05-09', 'Писатель', 'Пало-Альто, СА', 'Не замужем', 'Каяк, террариум' 
'Друзья); 


Где ошибка? Последнее значение не завершается апосилрофом. 
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Модификации Команды ІМ№ЗЕКТ 


У синтаксиса ТМЗЕВТ существует ряд модификаций, о которых следует знать. 


ев Изменение порядка столбцов 
Порядок столбцов можно изменить — при условии, что зна- 
чения будут перечисляться в соответствующем порядке! 
Порядок перечисления 
силолбиов изменился. 


ІМЅЕКТ ІМТО шу сопіасіѕ Р. А млелерь лосмо — 
(іпёегезіѕ, Ғігзі паше, 1азЕ папе, депӣег, ета11, рігіһаауү, ирии на значения: 
ргоёеззлоп, Іосаёіоп, зёаіџз, зеекіпо) они перечисляюился 
ом же порядке. 
УАТАЛЕЗ Вил В 
Еб 
('Каяк, террариум', 'Джиллиан', 'Андерсон', 'Ж', и 


'3111 апаегзоп@Бхеакпескр1=2а.сош', '1980-05-09', ‘Писатель’, 
'Пало-Альто, СА', 'Не замужем', 'Друзья'); 


12) Не указаны имена столбцов 
Список столбцов можно опустить, но тогда все значения должны 
быть указаны в порядке перечисления столбцов при создании 
таблицы. (Если не уверены, проверьте порядок в команде на с. 73.) 


Имена силолӧцов можно 


ТМЗЕВТ ІМТО пу сопбас+з не указываиль, но илогда 


б. необходимо задаиль ВСЕ 
= Значения в ТОЧНОМ 
('Андерсон', 'Джиллиан', ')111 апдегзоп@геакпескр1 та. ПОРЯДКЕ их следо- 


сош', 'Ж', '1980-05-09', 'Писатель', 'Пало-Альто, СА', 


ания б иладлице! 
'Не замужем', 'Каяк, террариум', 'Друзья'); 


|3) Не указаны некоторые значения 
В списке значений отсутствуют данные некоторых столбцов. 


ІМЅЕКТ ТМТО шу сопіасіз е 
(Іазї пате, Ғігзі папе, ешаі1) Р Ф МОЗГУ 
ОТ ШТУРМ 


УАЪОЕЗ 
2 
Ра ('Андерсон', 'Джиллиан', '5111 апаӢегзопё 
| Бгеакпескра=ха.сом'); Как вы думаете, что 
\ я и. Так как РСУБД хранится в столбцах, 


ис 
лииль часиль данных зат 
ропущены, для всех заданных 


мена силолдиоб. 


которым не были при- 
своены значения? 


5 
+ оманда заполняем 
не знаеил, какие именно значения и, 
‘начений необходимо явно указаиль и 
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(Столбцы без значении 


Давайте вставим в базу данных ту сопфас®з СОГОММ5 : УАГОЕЗ : 
анные из неполной карточки: 
А р р „ > 1азЕ пате ? 


Неил данных о фа- 


на. Щ Милии и даиле рож- Ғігзі пате Пэт 
Пэҝмл РЕГ ы дения, да и с иолом етаі1 'раърозЕ@Ьгеакпескратта 
аиа = Неил особой уверен - 8 
Раа носили. е депаег ? 
Почилалеон о Ьзгенаау 2 
также силе чи“ Аа 
МЈ силвунюих значе \ ргоѓезѕіоп 'Почтальон' 
Принсилон, Д" 3 илолбиов сфаби$, 
раърозі@Ыгеаклескр а к вгезЕ и 56609: 1оса+1оп "Принстон, №' 
эсаЕаз ? 


РА іпёегеѕіѕ ? 
ѕеекіпд э 


Так как на карточке часть данных отсутствует, 


Грегу придется ввести неполную информацию. Здесь использ Нео 

Но в этом нет ничего страшного, недостающие С неполным набором о (МХЕ 

сведения можно будет добавить позже. позволяющая АИ, начений, 
извесилны "ИОлвко 


е зн 
Г ачения силолбиов. 


ТМЗЕВТ ІМТО ту сопіасёз / 
(Ғігѕі пате, ета11, ргоѓезѕзѕіоп, 1осаііоп) 
УАТОЕЗ 


('Пэт', 'раіроѕіёЬгеакпескрі22а.сот', 
'Почтальон', 'Принстон, №'); 


Еіе Еа \Мипдом Нер МогебааР!еазе 


> ТМ5ЕВТ ІМТО ту сопфасе$ (Е1х5$е пате, ета11, ргоѓеѕѕіоп, 
1осаЕ1оп) УАШЈЕЅ ('Пэт', 'раіроѕіёргеакпескріхха.сот', 


'Почтальон', 'Принстон, №'); 


Оцегу ОК, 1 гом аЕЕесееа (0.02 ѕес) 
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значения коилорых 


Силолбие! ) 


5 
а. 
=. 
= 
= 
< 
Ж 
9. 
> 
© 


даны, 


со 


не были за 


| 1осаёоп 


| реобезззоп 


| Чепдег | ЬігеҺдаү 


епаі1 


1азе пате | #ігѕб-пате | 


се 


СА | Не замужем | Каяк 


| Принстон, № © | моц, 


7 


> 
п] мос Сә) | Почтальон 


| раброзЕйвтеаклескраета. сай 


| Пало-Альто, 


| 1980-05-09 | Писатель 


3111 апдегвоп®Ьтеахлескрахха.сом | Ж 


| Джиллиан 


Андерсон 


том іп вес (0 


Команда ЗЕГЕСТ читает данные 
из таблицы 


Хотите посмотреть, что у вас получилось? Команда РЕЗС 
уже не подойдет — она выводит только структуру таблицы, 
но не хранящуюся в ней информацию. А для вывода дан- 
ных, хранящихся в таблице, используется команда выборки 
ЅЕ1ЕСТ. 


Мы хоилим вы - 
браиль все дан - 


ные из иладлицы... , звездочка именно 
эило и означаеи: имя 
‚с выбрамь ВСЕ. ААЦ 
м 


ЗЕТЕСТ * ЕВОМ ту сопіасіз; 


Для нас пока несуще- 


ў АССЛАРЮТЕСО ственно, как работает 


команда ЗЕЦЕСТ. 


: Эта команда будет подробно рассмотрена в гла- 
: ве 2. А пока просто расположитесь поудобнее и 
: насладитесь красотой созданной вами таблицы. 


Попробуйте сами. Вероятно, для просмотра результатов 
окно консоли придется растянуть по горизонтали. 


ый 
х1 МОЗГОВОЙ 


<) 


ХУ ШТУРМ 


Итак, в столбцах, которым не присвоены 


значения, выводится М011.. Как вы думаете, 
что это значит? 
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ОТКРОВЕННО ОБ 858. 


Интервью недели: 


Признания МОЦ. 


Неаа Еігѕ: Добро пожаловать, МОШ. Чест- 


но говоря, немного странно видеть вас здесь. 


Мы даже не думали, что вы действительно 
существуете. По слухам, вы — просто нуль, 
то есть вообще ничто. 


МОШ: И вы поверили этой грязной лжи? Да, 
я здесь, и я абсолютно реален! А вы, значит, 
думаете, что я — ничто, пустое место? 


Неаа Еігѕ: Спокойно, спокойно... Просто 


вы всегда появляетесь там, где нет значения... 


МОШ: Еще бы — уж лучше я, чем нуль или, 
скажем, пустая строка. 


Нега Еігѕќ: Пустая строкаг.. 


МОШ: Значение из двух апострофов, между 
которыми нет ни одного символа. Оно все 
равно рассматривается как текстовая строка, 
но имеющая нулевую длину. Скажем, как 
если бы столбцу ғігѕх пате в таблице 

ту сопбасїѕ было присвоено значение ". 


Неаа Еігѕ: Выходит, вы не просто хитроум- 
ный синоним для «ничто»2 


МО: Говорю же, я не «ничто»! Я есть! Про- 
сто мое состояние немного... неопределен- 
ное. 


Неаа Р!г${: Выходит, если сравнить вас 
с нулем или пустой строкой, вы не будете им 
равны? 


МОШ: Нет! Я никогда не равен нулю. Более 
того, я даже не равен какому-нибудь другому 
МІЛА. Сравнивать два МОТ, между собой 
нельзя. Столбец может содержать МОЦ, но 
его значение никогда не равно МОЦ, по- 
тому что МОМ, — неопределенное значение! 
Понимаете? 


глава 1 


Неаа Еігѕќ: Успокойтесь и давайте разберем- 
ся. Вы не равны нулю, вы не равны пустой 
строке. И вы даже не равны самому себе! Как- 
то это странно, вы не находите? 


МОШ: Знаю, это нелегко понять. Считайте, 
что я не определен. Я — как содержимое за- 
крытой коробки, в которой может лежать 

все что угодно. Сравнивать одну закрытую 
коробку с другой нельзя, потому что вы не 
знаете, что лежит в этих коробках. Они во- 
обще могут быть пустыми. Что внутри — неиз- 
вестно. 


Неаа Еігѕќ: Говорят, иногда ваше присутствие 
нежелательно. В некоторых ситуациях МОГ, 
создает проблемы. 


МОШ: Признаю, бывали и неприятные си- 
туации. Некоторые столбцы всегда должны 
иметь определенное значение — например, 
столбец фамилии. Бессмысленно создавать 
в таблице описание человека с неопределен- 
ной фамилией. 


Неаа Еігѕќ: Так вы не будете появляться там, 
где вас не должно быть? 


МОЕ: Точно! Только скажите! При создании 
таблицы и определении столбцов укажи- 

те: в этом столбце МОЕ быть не должно. 

И я там не появлюсь. 


Неаа Еігѕё: Вообще-то вы не похожи на за- 
крытую коробку. 

МОШ: С меня хватит. Извините, мне пора — 
у меня куча дел. 


Управление МИЦ. В таблицах 


Некоторые столбцы в таблице всегда должны иметь определенное зна- 
чение. Помните неполную карточку, в которой стояло только имя Пэт 
без фамилии? Когда в вашей таблице еще два десятка записей с МОГ 
вместо фамилии, найти такую запись будет трудновато. К счастью, 

вы можете легко запретить присваивание МОТ, столбцам таблицы. 


Просило добавьиле слова 


СВЕАТЕ ТАВЬЕ ту сопфас®$ / МОТ МОЦ. после илила 


данных. 
( Е 


/ ме \ 
1азЕ пате УАВСНАВ (30) МОТ МОШ, Значение. о в 


силолбиа 


Ғігѕё пате УАВСНАВ (20) МОТ МО, 93 р 


); случае РСУБД выдасил 
сообщение об ошибке. 


г. Возьми в руку карандаш 


Взгляните на столбцы таблицы 


< ту_сопїасїѕ в команде СВЕАТЕ 
СВЕАТЕ ТАВЬЕ тү сопёасіз ТАВІЕ. Какие из них следует снабдить 
= условием МОТ МОТ? Подумайте, 
( какие столбцы никогда не должны со- 


Лазе п УАВСНАВ (30) МОТ МІЛІ, держать МОТ, и обведите их кружком. 


= 20 т Мы уже выделили два таких столбца; 
ігѕё пате УАВСНАР (20) МОТ МОЛІ, разберитесь с остальными. Обращайте 


&та:1 \УАВСНАВ (50); особое внимание на столбцы, которые 
позднее будут использоваться для 
депдег СНАВ (1), поиска или содержащие уникальные 
; значения. 
ЬЪігіһау РАТЕ, 
ргоЕезз1оп УАВСНАВ (50), 
1осаёіоп УАВСНАВ (50), 
зЕафоз УАВСНАК (20), 
іпіегеѕзіз УАВСНАВ (100), 
ѕзеекіпд УАВСНАВ (100) 
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Возьми в руку карандаш 
ян О Взгляните на столбцы табли- 
У цы ту сопбас®з в команде 


СВЕАТЕ ТАВІЕ шү сопіёасіз СКЕАТЕ ТАВІЕ. Какие из них следует 
= снабдить условием МОТ МОГ? Поду- 


т 7994 майте, какие столбцы никогда не должны 


Таз паше УАВСНАВ (30) МОТ ых содержать МОТ, и обведите их кружком. 


Мы уже выделили два таких столбца; 


Е1гзЕ пате УАВСНАВ (20) МОТ МОБ, разберитесь с остальными. Обращайте 


етаі1 УАВСНАВ (50), особое внимание на столбцы, которые 
позднее будут использоваться для поиска 
деп4ек СНАК (1), или содержащие уникальные значения. 
Ьіг+Һаау РАТЕ, 
ргоҒеззіоп УАВСНАВ (50), Я Р 
се силолдцы должны быиль 
\ 1осабіоп УАВСНАВ (50), р. объявлены с ключевыми сло- 
\ збасиз УАВСНАВ (20), Вами МОТ МОЦ. 
% іпёегеѕзіѕ УАВСНАВ (100), 
`` зеекаля УАВСНАВ (100) ВСЕ силолдце илаблицы будуил исполь- 
Я рУ зоваилься для поиска. С самого начала 


силоиил позадоилиилься о илом, чилобы все 
записи содержали полную информацию. 


цо если В плаблиие есиль силолдиы, коило- 
бидцил замолняилеся позднее, для илаких 
дцов силоиил разремлииль значения МУ. 


рые 
Силол 


— 


МОТ МОЦ 8 Выходных данных 0Е$0 


А вот как будет выглядеть таблица ту сопёасіёѕ, если объявить все 
столбцы с ключевыми словами МОТ М№О11: 


Ейе Еди \У/Модом Нер МоМогемиі..5 


СВЕАТЕ ТАВЬЕ му сопіасіѕ 
( 


1азЕ пате УАРСНАК (30) МОТ МОТ, 


Ғігѕ пате УАВСНАВ (20) МОТ МОШ, 
ема11 УАВСНАВ (50) МОТ МОЦ, 
депаег СНАВ (1) МОТ МО, 


Команда созда- 
бил иладлицу, рігіһаау РАТЕ МОТ МО, 


у коилорой Я 

бее а ргоЁезз1оп УАВСНАВ (50) МОТ МИШ,, 
це одъявлены 1осабіоп УАВСНАВ (50) МОТ МОБ, 

г МОТ МОЦ. 


з+аеаз УАВСНАК (20) МОТ МО, 
1п$егез*$ УАВСНАВ (100) МОТ МОШЕ, 
ѕзеекіпд УАВСНАК (100) МОТ МЈІ1 

); 

Оцегу ОК, 0 гомз аЁҒесеа (0.01 зес) 


> РЕЗС му сопіасіѕ; 


а уагсрах (30) 


+ = р ано вы о д чае 
РреҒачі+ 


Описание Ғігѕі пате | уагсвахг (20) 
иладлицы. етаі1 | уагсһаг (50) 

драмите депдег сћаг (1) 
нимание Ь1гЕБаау дасе 

на слово МО Я 0 

б силолбие ргоѓЁеѕѕіоп уагсћһаг (50) 

МИЕЕ. 1осаёіоп уагсвахт (50) 


$Баба$ уагсћһах (20) 
іпёегеѕіѕ уагсћһаг (100) 
уагсҺах (100) 


10 гомз іп ѕеё (0.02 зес) 
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ОЕРАЦИТ и значения по умолчанию 


Если в столбце часто хранится какое-то одно конкретное значе- 
ние, ему можно присвоить значение по умолчанию при помощи 
ключевого слова РЕРАОГТ. Значение, следующее за РЕҒАОІТ, ав- 
томатически заносится в таблицу при каждом добавлении новой 
записи — если не задано другое значение. Значение по умолчанию 
должно соответствовать типу данных столбца. 


Эилоил силолдец ВСЕГДА 
должен содержаиль значение. 
Для эилого мы не илоль - 


с ТЕ ТАВІЕ Зопавпие 113% ко объявляем его с ключе- 
ВЕА — вВыми словами МОТ МИРЕ, 
| но и ирисваиваем значение 


ло умолчанию 1. 


бӢоодһпиё пате УАВСНАВ (10) МОТ МОШЕ, 

ЧочавпаЕ уре УАВСНАВ(6) МОТ МО, $ 
бӢоцдћпиё созЕ ВЕС (3,2) МОТ МО РЕЕАОТТ 1.00 
); | 


Значение можеих содержаиль Эило значение сохраняеился 
до 5 цифр: одна до и две после 6 силолдие ЧоцарииЕ сос, если 
запяилой. 6 команде ІМЅЕРТ не указано 


другое значение. 


аоцдћпиб 11іѕЁ 


Уеловие –ЕРАСИТ. 
заполняет пустые 


/ 


| етолбцы заданным 
Так будеил Выглядеиль иладлица, если при значением. 


всилавке данных пончиков Стлиаилойдо, 
Роскзваг и Сагаилейег не чказываиль 
значение силолдиа аоиділли соѕЁ. 
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КЛЮЧЕВЫЕ 
МОМЕНТЫ 


ату. 
у 


Для вывода описания структуры таблицы 
используется команда РЕБС. 


Команда ОВОР ТАВЬЕ уничтожает таблицу 
со всем содержимым. Будьте внимательны! 


Для сохранения данных в таблице исполь- 
зуется команда ТМЗЕВТ, которая существу- 
ет в нескольких вариантах. 


мы, — неопределенное значение, которое 
не равно нулю или пустой строке. Для 
столбца, содержащего МОТ, выполняется 
условие 1$ МОЛІ, но при этом он не равен 
мо. 


Столбцы, значение которых не указано 
в команде тм$ЕВТ, по умолчанию инициа- 
лизируются МОИ. 


Чтобы запретить хранение МЛ в столбце, 
используйте ключевые слова МОТ МОЛ, 
при создании таблицы. 


Условие РЕЕАОТТ определяет значение по 
умолчанию — если при заполнении табли- 
цы значение столбца не указано, он авто- 

матически заполняется этим значением. 


СВЕАТЕ ТАВТЕ 


Команда соз 
Но для ее вы 


обходимо знать И 
МЕН 
ТИПЫ ДАННЫХ менна, 
Они определяются на ос 
нобе анализа ин 
коилорая буде 
иладлице. 


млл, и МОТ МОТ, 


При соз 
знаиль, 


дании базы данных следцеил 
какие силолбиы не должны 


принимаиль ей мол, — эило 
иросилиил сорилиробку и 

Зра Условие мот МО, задаеился для 
силолбиов при создании илаблицы. 


поиск дан- 


РЕЕАОЬТ 
Определяеил значение по умолча- 


нию для силол 
6 илом случае, если значение силолбца 


не указано ири всилавке силроки. 


бца; оно используется 


Мы подошли к концу главы 1. 
Вы научились создавать 
базы данных и таблицы 


и вставлять в них данные некоторых 


распространенных типов. Кроме того, 
вы знаете, как обеспечить наличие 
определенного значения у столбца. 


даги илаблицц, 
полнения ңе ~ 


формации, 
ил храниилься 
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Новые инструменты 


ГУУ 
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Компания ключевых слов и типов данных ЗСЕ, облаченных 

в маскарадные костюмы, развлекается игрой «Кто я?». Игрок 
дает подсказку, а остальные на основании сказанного им пы- 
таются угадать, кого он изображает. Будем считать, что игроки 
всегда говорят правду о себе. Если сказанное ими может 
относиться сразу к нескольким персонажам, перечислите всех, 
ккому может относиться их высказывание. Заполните пропу- 
ски справа именами одного или нескольких участников. 


Сегодняшние участники: 


СВЕАТЕ ОАТАВАЅЕ, У$Е ОСАТАВАЅЕ, СКЕАТЕ ТАВІЕ, 
ОЕ$С, ОКОР ТАВІЕ, СНАК, УАКСНАК, ВОВ, РАТЕ, 
ОАТЕТІМЕ, РЕС, ІМТ 


Поможем с хранением чисел. 

Занимаюсь устранением нежелательных таблиц. 
Специализируюсь на вопросах Да/Нет. 

Помогу запомнить день рождения знакомого. 

Во мне хранятся все таблицы. 

Числа — это хорошо, но я ненавижу дроби. 
Люблю длинные, подробные объяснения. 

Место для хранения ВСЕГО. 


Без меня таблица не могла бы существовать. 


Точно знаю, когда вам нужно явиться к врачу на следующей неделе. 


Сохранить денежную сумму? Без проблем. 
Вывожу описание формата таблицы. 


Без нас вы вообще не сможете создать таблицу. 


Кто яр 


= и" 
СНА)... ОЧКА мем, 
и 
(1. 


ОЗЕ РАТАВАЅЕ 
РКОР ТАВІЕ 


2 К-манла СТ 


ж 
. Выборка данных * 


ЅЕІЕСТ * РВОМ 911$ 
М/НЕВЕ сопїепїѕ = «дорого»; 


При работе с базами данных операция выборки обычно 
выполняется чаще, чем операция вставки данных в базу. В этой 
главе вы познакомитесь с могущественной командой ЗЕЪЕСТ 

и узнаете, как получить доступ к важной информации, которую 
вы сохранили в своих таблицах. Также вы научитесь использовать 
условия ММНЕКЕ, АМ№О и ОК для избирательной выборки данных 

и предотвращения вывода ненужных данных. 


Трудный поиск 
Грег наконец-то перенес все данные из своей картотеки П 


в таблицу ту сопёсасіз. Теперь ему хочется отдохнуть. 
Он раздобыл два билета на концерт и хочет пригласить 
одну из своих знакомых — девушку из Сан-Франциско. 


Чтобы найти ее адрес электронной почты, Грег просматри- 
вает содержимое таблицы командой ЗЕЦЕСТ из главы 1. 


Энн из Сан -Франциско 


ЅЕ1ЕСТ * Егом ту сопіасіѕ; 
ви 7 
( 


Данные храняился 
6 илаблиие Грега.. 
где -ило. 


СТАТ Трегем 


" Теперь постраВьтре себя на Место | Рега. [Просмотрите 
начало трабЛиЦы тпу__соп[асіє на следующей странице 


и по Отре найтри В ней Зин из ( ан- анциско, 
7 проёу Энн из (ви-Фр 
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Таблица илу_солёасё$ сосилоиил те 
из многих силолбиов. Здесь моказ 


лишь начало илаблииы. 


Е1гз& пате ета11 1осаёіоп 


Пало-Альто 
Сан-Хосе, 


Андерсон Джиллиан 3111 апдегзоп?ргеакпескрі22а. сом 
Иоффе Кевин Эоевз1тадаск. сот 

Ньюсам Аманда амап210џуёЬгеакпескрігха. сом 
Гарсиа Эд ей99@Ь0+60тѕир.сот 

Раундтри Джо-Энн јојогоцпаёргеакпескріг2а. сот 
Вриггс Крис сргідаз@роагаѕ-г-из. сот 

Харт Һоуегсга#ёргеакпескріг2а. сот 
Тот Аппле то+һ@1еаріп1ітоз сом 

Уайли апігеммі1оуйоб јесіёчі е. пеЕ 
Паламбо ра! оѓаіпебтіо + усипра і г. пех 
Райан апотурёгаіедьтеакпескрі22а.сош 
Маккинни Й сіауёзіагьог2=соЁѓее.сот 

Микер аги. ест с? ъо1іс-іпс.сотм 
Пауэрс Бр +57ъу 3016.сом 

Мэнсон ать60:ъјесіёуі11е.пеі 

Мендел ЗеблопзћекБтелкпескгеі тта, сом 
Тедеско запі зіесјезсойвњагрюы2 тсоѓ Ѓее. сом 


Сан-Хосе, 
Сан-Франци 
Нью-Йорк - 
Принстон, 
Сан-Фра 
Нью-Йорк, 
Сан-Франци 
Напа, СА 
Сиэтл, ИА 
Натчез, М5 
Лас-Вегас, 
Талвар узксезсаграхасоЕ Еее. сом Пало-Альт 
Швед ѕтмеа јоеёорјегіуі11е.пе 
Шеридан зћһегіаіёті аћёусотра11. пе 
Сноу зпомтап@{1К1Безо1оипде . сом 
Отто а1еппӣ098@ођјесіхі11е .пеё 
Харди аппеһёро сЕОшзир. сом 

Дил побісдеа1@зіагіц22со ее. сот 
Джейгел агеапаіг1ёргеакпескріт2а.сот 
Мелфи Зтте1 #1850++0тзир сот 

Оливер ее зрзуюгюмеасиегогама . сот 


Сан-Францис 


Сент-Луис 
Сан-Фран 
Рено, МУ 


Паркер апперёѕзісагоиг2соЁѓее . сот 
Риччи гіссіљмапёіікіреап1оопде. сот 
Рено И агасе23@орјесіуі11е.пеё 

Мосс теі даёиеаіћегогата . сом 

Дэй с\1іҒҒпісћ+ геакпеекрі 22а. сот 


Саннивей? 
Честер, М 
Болгер ]оусевспосопо11<  іпс, сот Остин, 
Плант аппеб] оп @геакпескр1=га. сот 
Воллинг 1іпауёїікіђеап1оџпде. сом 


Гарес Ғдагеѕ@оЬјесіуі11е.пеё 


Ж 
М 
Ж 
м 
Ж 
м 
м 
Ж 
М 
м 
Ж 
М 
Ж 
м 
М 
Ж 
Ж 
м 
м 
Ж 
М 
М 
Ж 
Ж 
Ж 
м 
м 
Ж 
М 
Ж 
Ж 
м 
Ж 
Ж 
Ж 
М 


Сан-Хосе, 


обс Сан-Хосе, 


11 тило еще Не конец! У Грёга в 
ОЧЕНЬ МНОГО карилочек. 
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Г 


ет [Регем . (завео 


Вы должны ёылч представить 
себя на Местре Грег, про 
<Мотпретьъ наЧаЛо трабЛиЦы 


тоу_ сока, найти Всех З= 


из { ан—< Франписке ч за– 
писать их имена, Рами 
Лии и адреса электронной 


почты, 


Ищем Контакт 


Поиск занял слишком много времени 
и был исключительно нудным. Также 


существует весьма реальная опасность того, 
что Грег пропустил пару-тройку подходя- 
щих Энн, включая ту, которую он ищет. 


Зная адреса электронной почты, Грег рас 
сылает сообщения и получает ответы... 
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То: Блант, Энн <аппеШипі@ргеакпескрігга.сот> 


Егот: Грег <огед@9гед%ііѕ.сот> 
Ѕирјес: Мы встречались в Ѕіагбиг2? 


Ковбой, ты-то мне и нужен! Заедь за мной в пят 
зайдем куда-нибудь перекусить. 


оъмезговой 
ШТУРМ 


Сможете ли вы написать запрос 50 
для выборки только тех записей, 
у которых столбец Ғігѕї пате 

содержит строку «Энн»? 


То: Харди, Энн <аппећ@Ь0Отѕир.сот> 
Ргот: Грег <9ге9@дгед$ $. сот> 
ЗиБес: Мы встречались в З{аБиг2? 


Я не та Энн, которую ты ищешь, но я уверена, 


что она того стоит. Если что- -то не срастется — 
напиши мне. 


Тоил, Энн: Алие Тоё ё@Іедріліѓилоѕ.со, 


Харди, Энн: аллелероЕОрулѕир.соил 


Паркер, Энн: реа ис ее. сои, 


Бланил, Энн: аллеи @БегеаКиесКриа.соу 


) 


Разные Энн и адреса их 
элекилронной почил. 


То: Тот, Энн <Аппе_То@еармИтоз.сот> 
Егот: Грег <дгед@дгед$И®.сот> 
Ѕибјесі: Мы встречались в З4афи27? 


Я сейчас встречаюсь с отличным парнем, его 
зовут Тим Вудман. Мы встретились на студенче- 
ской вечеринке. 


То: Рагкег, Аппе <аппер@$атфиг2соНее.сот> 
Ргот: Сгед <9гед@одгед$!$1.сот> 
Ѕибјесе: Мы встречались в З{агБиг22? 


Конечно, я тебя помню! Жаль, что ты не написал 
раньше. Я уже договорилась с моим бывшим паг 
нем, который хочет начать все заново. 


Улучшенная Команда ЗЕТЕСТ 


Следующая команда ЅЕІЕСТ поможет [регу отыскать данные Энн намного 
быстрее, чем при дотошном просмотре всей огромной таблицы. В этой 
команде мы используем условие ИНЕВЕ, которое уточняет критерий отбора 
записей для РСУБД. Условие сужает результаты поиска, а команда возвра- 
щает только те записи, для которых это условие выполняется. 


Знак = в условии ИНЕВЕ означает, что каждое значение столбца 

11086 пате проверяется на равенство с текстом 'Энн'. Если два значе- 
ния равны, то вся запись включается в результат выборки. Если нет — 
"пись пропускается. 


имя иладлице! Посилавьиле сим- 
7А вол «;> и нажми - 
иле КЕТИКМ, Чилобы 


ЅЕТЕСТ * ЕВОМ пу сопфасез Выполнииль запрос: 


«Если силолдец Рус 
ЕРА паиле содержиил 


а — ' Ё'. 
Е Ғігѕ пате = Энн ГА НЯ «Энн», лока - 


М к заиль запись». 
/ р 


Ключевое м В чслобии МНЕВЕ = на языке Бу 

НЕВЕ со0 6% эило означаеил, ЗОЕЁ эило Значение силолбиа НузЕ паиле. 
РСУБД, вся браиле Чило команда иро- означаеил Не забчдеиле, ЧИЛО илексило- 
ивилииле сил Р А верясил значения «равна» вые значения должны заклко 
цё улаблицо и исей. СИлолдиа с именем чвилься в амосирофе!. 
множесилво зами Низ лаиле. 


В гом окне консоли показан результат запроса — подмножество 
анисей, у которых столбец Ёігѕі папе содержит значение 'Энн'. 


= Ри! МУМпадом Нер Мобае 


ЕГЕСТ * ЕВОМ ту сопфасЕз ИМНЕВЕ ѓїіхѕ папе = 'Аппе'; 
+------------------------- +-------- +---------- 
Ъ1гЕРдау 


Аппе Тоћ@1еаріп1ілоѕ.сом | Ж Сан-Франциско, СА| 


ап 6йоЬјесёуі11е.пеб і ж Сиэтл, МА | 
апперв Бо Е0тзир . сом РЖ Сан-Франциско, СА| 
апперё@ѕ+агьц22соЁѓее.сош| Ж і Сан-Франциско, СА| 
апперіџп в геакпескріг2а.соп| Ж Сан-Франциско, СА| 
аппе99@орјесіуі11е.пеё і Сан-Хосе, СА | 

чеее-ее--е-н-е--- + 


гомз іп зеЕ (3.67 вес) 


Резульилаил Выполнения 
—— команды ЗЕЁЕСТ. 
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а. ВНА, 


Минутку, вы же не думали, что я не замечу 
знак * 2 Что он здесь делает? 
ое ОР ЕЕ ИЕН. о 


Что это за * ? 


Звездочка (*) приказывает РСУБД вернуть зна- 
чения всех столбцов таблицы. 


Когда вы вВидииле ЅЕІЕСТ * 
аи, Чило Эрла кон- 
и\РУкиия ириказыва %- 
РСУБД бернциль 8 Г 
ВСЕ СТОЛБЦЫ. 


~ Часто 
ЗадаВаеМые 
Восы 
д узнаете, как ограничить выборку частью 
• А еслия не хочу включать столбцов, чтобы с результатом было про- 
в выборку все столбцы? Можно ли ще работать. 
использовать что-то другое вместо 
звездочки? 
‚ Есть ли другие символы, которые, 
(} Да, можно. Звездочка выбирает все как и звездочка, имеют специальное 
столбцы, но через несколько страниц вы значение? 
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ЅЕТЕСТ * ЕКОМ ту сопіасёѕ 
МНЕВЕ ғігҳё папе = 'Энн'; 


Я — звезда! 
за 
молеЗЧ 
очка ех 
зне Эля 6 ркі бе 
им ‹ и! 
силолбцов у 


( В Заг есть и другие специальные 
(зарезервированные) символы, Мы ец 
встретимся с ними позднее в этой кни 
А пока вам достаточно знать только о} 
специальный символ — звездочку. Тог 
этот специальный символ используете 
в части ЗЕЪЕСТ команды АЕ. 


Бар Невада Еігѕї Соипде включает в свое меню фруктовые коктейли. Используя то, 
пражнение “То вы Узнали в главе 1, создайте таблицу и вставьте в нее приведенные ниже данные. 


Таблица входит в базу данных с именем аг1пкз. База данных содержит таблицу 
еазу ігіпкѕ с рецептами напитков, состоящих всего из двух ингредиентов. 


еазу агіпкѕ 
Гатоеет [ звеня | 


ананасовый сок 
черничный сок 


тоник 


взболтать со льдом, разлить по бока- 
лам, украсить лимонной цедрой 


1.5 взболтать со льдом, разлить по бока- 
лам, украсить лимонной цедрой 
Воттебе на персиковый 1 ананасовый сок взболтать со льдом, 
нектар разлить по стаканам 
Спрайт 1:5 сок лайма взболтать со льдом, 
разлить по бокалам 
вишневый 2 абрикосовый подавать со льдом и соломинкой 
сок нектар 
персиковый Е апельсиновый влить в кружку горячий апельсино - 
нектар сок вый сок, добавить персиковый нектар 
ВЕ 
ЕҢ 
ПЕ 
ый 


Лаймовый 
физз 


Поцелуй 


Горячее золото 


1 
0.75 
1 
0.75 
7 
Одинокое содовая вишневый сок 0.75 взболтать со льдом, 
дерево разлить по бокалам 
Борзая содовая грейпфрутовый 5 подавать со льдом, 
сок тщательно взболтать 
5 
1 


Бабье лето яблочный налить сок в кружку, 
сок добавить горячий чай 
лимонад подавать на льду с ломтиком лайма 
виноградный взболтать в бокале, подавать без льда 
сок 


еэ 9 Значения арлоииё1 и аилоии2 


задаюился 6 унииях. 


‘ 7 (завета на с. І. 


[№ Не жалейте времени на планирование. 


Чльтое | Тщательно выбирайте типы данных 
р остророжнНы, и не забывайте о мот... Затем проверьте 
: свой код на с. 151. 


Лягушка холодный 
чай 
содовая 


Сода плюс 
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„ Возьми в руку карандаш 
ь\ Получите сбой напиток 


а незна = А Ы У 
осах лоладањюился " сь. Воспользуйтесь только что созданной таблицей 


зди илё А 
Если 6 3 СОНА — не бесмокои муле, ёазү_Фгіпкз и проверьте эти запросы на своем 
коме! а Эииле их и пос мои^Р компьютере. Запишите, какие напитки вернет каждый 
просило 7 выполнен запрос: запрос. 


ЅЕГЕСТ * ЕВОМ еазү Аг1пКз МНЕВЕ шаіп = 'Спрайт'; 


Какие напитки? 


ЅЕГЕСТ * ЕВОМ еазү дгіпкѕз МНЕВЕ ша1п содовая; 


Какие напитки? .........................................................а.. 


ЗЕЦЕСТ * ЕВОМ еазу йгіпкз ИНЕРЕ амоцпе2 = 6; 


Какие напитки? ................... ани ии нянннь 


ЅЕЕСТ * ЕВОМ еазу_Ах1пКкз ИНЕВЕ зесопа = "апельсиновый сок"; 


Какие напитки? 


ЗЕТЕСТ * ЕВОМ еазу Пгіпкз ИНЕВЕ ашоцпе1 < 1.5; 


Какие напитки? 


ЅЕГЕСТ * ЕВОМ еазу_Аг1пКз ИНЕВЕ атоџпё2 < '1'; 


Какие напитки? 


ЅЕ1ЕСТ * ЕВОМ еаѕу йгіпкзѕ МИНЕКЕ шаіп > 'содовая'; 


Какие напитки? 


ЗЕЦЕСТ * ЕВОМ еазу йгіпкѕ МНЕВЕ атоџпё1 = '1.5'; 


Какие напитки? 
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Один момент... Вы говорите: «Проверьте 
эти запросы». Значит, предполагается, 
что все они работают. И я вам поверила! 
Но один запрос вообще не работает, 

а еще несколько выглядят сомнительно. 


Да, вы абсолютно правы. 


Один запрос вообще не работает. 
А несколько других работают, хотя 
вроде бы и не должны. 


Вопрос на повышенную оценку: напишите, какой запрос не работает... 


...И какие запросы работают, хотя, казалось бы, работать не должны. 
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‚ ВОЗЬМИ В руку карандаш 


` 


С. 


ЅЕГЕСТ * ЕВОМ 


Какие напитки? 


ЅЕІЕСТ * ЕВОМ 


Какие напитки? 


ЅЕІЕСТ * ЕКОМ 


Какие напитки?. 


ЅЕГЕСТ * ЕВОМ 


Какие напитки? 


ЅЕГЕСТ * ЕВОМ 


Какие напитки? 


ЅЕГЕСТ * ЕВОМ 


Какие напитки? 


ЗЕЦЕСТ * ЕКВОМ 


Какие напитки? 


ЗЕТЕСТ * ЕВОМ 


Какие напитки? 
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„Горячее. золото..Бадее. леило................ м0 


шение Получите свой напиток 


Итак, вы воспользовались таблицей еазу йгіпкз, 
проверили запросы на своем компьютере и записали, 
какие напитки вернет каждый запрос. 


еаѕу дгіпкѕ ИНЕРВЕ ша1п = 'Спрайт'; 


Ф, =. Обраилимле внимание 


„Лаймеовый.фиЗ3......... ии 2 


ам ина алосилро Ы. 


еазу бгіпкз ИНЕВЕ ша1п = содовая; 2 


Хм... Похоже, эилоил запрос ее 


ВЕНЕ = 
вылолняилься не дудеим. 


илаем^. Пере 


бо 
а килиму РЕС 


фе не нужне! 


= заирос 
еазу Аг1пкз ИМНЕВЕ ащоџпё2 = 6; А а оилносии^ 
менна 


иломМЧ амоси^ро 


еазу дгіпкз ИНЕРЕ зесопа = "апельсиновый сок"; 


еазу йгіпкѕ ИНЕВЕ атоцпё1 < 1.5; 


Воил иледе на 


еазу дгіпкѕ ИНЕВЕ ашоџпё2 < '1'; в» 


ВО О НОО БВ 


еазу_Ах1пКкз МНЕВЕ шаіп > 'содовая'; Еиде одно правильно 


— сформулированное 
условие \/НЕКЕ. 


еаѕү йгіпкѕ ИНЕВЕ ашоипЕ1 = '1.5'; 


зне 


Терновник, Голудая луна, Лаймовый физз, Одинокое дерево, Борзая, Лягу 


Вопрос на повышенную оценку: напишите, какой запрос не работает... 


Знач 

м С/лолдца МАР. 'НАР 

5 Но быть заключен =» 
яиосилрофы. : 


>=» МНЕВЕ таїп = содовая; 
...И Какие запросы работают, хотя, казалось бы, работать не должны. 


~ МНЕВЕ ѕесопа = "апельсиновый сок"; 


Запрос выполняеился без ошибок, хоиля 
7 ) 

И бсилавке значения использовались 
построфы вмесило кавычек. 


емл, ХОМАЯ 


__ < МНЕВЕ амоџпі2 < '1'; затрос Работ олжен, по" 
аве 4 Вроде 00! Г 4016 
МЧА. лому чило парата очатто 


Последние два запроса работают, потому что РСУБД обычно прощают 
незначительные ошибки пользователей. Они игнорируют апострофы 
и рассматривают значения рЕС и ІМТ как числа, хотя апострофы определяют 
их как текст. Эти запросы НЕПРАВИЛЬНЫ, но РСУБД исправляет вашу ошибку. 
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Как запрашивать разные типы данных 


Чтобы написать правильное условие ИНЕВЕ, необходимо правильно от- 
форматировать каждый из входящих в него типов данных. Ниже пред- 
ставлены правила форматирования для всех основных типов. 


ен 4АВАСТЕВ) ІМТ (или ІМТЕДЕВ) 
СНАВ сай ' оадемлся никогда не заключаеился 


да за 8 
К вада рою! построи, 


№ Мы ил 
ак г. 
г сокрашение | Кило эмо. ке Знаелд 
рес ( и ьа ® < | 
эа? РЕ # \ 3, 


„да не заключа щ°' 


ся 6 кавычки: 


коё 


ГАА 
ВОВ всегда 
заключаеился 
6 аиосилрофы. 


САТЕ НМЕ, ТЕМЕ 

е Е. с а А Ал р 
всегда заклю . 7 Е всегда заключаеил 
ЧАаилея 6 адо с ся апосилрофы. 
пирофы 


МАБСНАЕ всегда и 
заключается г 
В алосилрофе!. 


Типы данных УАВСНА 
СНАК, ВІОВ, РАТЕ 
и ТІМЕ записываютея 
в апострофах. 
Чиеловые типы РЕС 

и МТ запиеываютея 
без апоетрофов. 
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Проблемы со знаками препинания 


болив Фанион 


Дата рождения: 12/4/2470 
Грег нашел еще нескольких знакомых. Он пытается Панк 
ВКЛЮЧИТЬ ОДНОГО ИЗ НИХ В СВОЮ таблицу: Не женаил 


- Джерси 
Вер" Милл, Нею Дж 
Гро опіоиНауоғедн'тд= сот 


увлечения: биниларсилво 


У АЕ. сопёасіѕ ищем“: диномешленники; 
, а 
УА1.ЈЕЅ 


('Фанион','Стив', ' ѕіеуе@опіопЁ#1ауогейгіпдѕ.сом','М', 


'1970-01-04', 'Панк','Гровер' Милл, М№Ј', 'Не женат', 
'бунтарство', 'единомышленники, гитаристы'); 


Но сго РСУБД почему-то пе отвечает. Грег вводит несколько символов «;», 
пытаясь завершить обработку запроса. Безуспешно. 


Еіе Ед \Міпаом Нер Аііепѕ! 


> ТМ5ЕВТ ІМТО му сопбасёѕ УАШОЕ$ ('Фанион', 
оп10опЕ1ауогеЯг119$.сот', 'М','1970-04-01', 


Милл, МЈ', 'Не женат', 'Бунтарство', 
гитаристы'); 


'Стив', 'ѕёеуеё 
'Панк', 'Гровер' 
'Единомышленники, 


"Рчглаще 


ние: >. у мозговой 
ШТУРМ 


Как вы думаете, что происходит? 


Хм, а почему перед приглашением постоянно вы- 
водится апостроф? Наверняка какие-то проблемы 
с апострофами в команде ІМЅЕРТ.. 


ЗРЕИНИШРЕЗ2ЯЕНИЫРАРЕС С... 
Непарный апостроф 


Точно! Когда Грег попытался вставить запись, РСУБД ожидала уви 


четное число апострофов — по одному до и после каждого значени 
УАВСНАБ, СНАК и РАТЕ. Название города Гровер' Милл породило п' 


ницу, потому что в нем содержится лишний апостроф. РСУБД хоч: 
получить еще один закрывающий апостроф. 


Как вернуть консоль под свой контрол! 


Завершите команду — введите апостроф 


РСУБД выдас 5 и точку с запятой. РСУБД получает допол 
месо : нительный апостроф, который ожидает получить. 

общение об ошибке, : 

но поиродоваиль все : Правда, при этом будет выдано сообщение об ошибке, и вам при 

равно силоиил. : дется вводить команду ТМЗЕВТ заново. 


Ее Еді \М/Ипдом Неір ТакеТмо 


> ТМ5ЕВТ ІМТО ту сопбсасбѕ УАШЈЕЅ ('Фанион', 


'Стив', 'ѕіеуе@ 
опіопЕ1ауогедгіпдѕ.сот', 'М','1970-01-04', 'Панк', 'Гровер' 
Милл, МЈ', 'Не женат', 'Бунтарство', 'Единомышленники, 
Апосилроф с сим ВАА 


болом <<;> заверила Ы 


'> 
вил некорреки^ную 


команду ІМЅЕЁТ-\ "Эу 
'> 
0 ` 
бидение доволен 
сое уН объясняе и аЛ 
ик 2 
ИВ роисхой ЕВВОВ 1064 (42000): Үоџ Һауе ап еггок іп уоџг 501 ѕупѓбах; 
м ии 


сһеск ЕБе тапџоаі іһаі соггезропа$ Фо уопг 501 зегуег уегѕіоп: 
идёго: иаси^о Гог һе гідһе ѕупіах бо иѕе пеаг ' Милл, Нью-Джерси', 'Не 
илирЧе"^ начинаю женат', 'Бунтарство', 'Единомышленники, гитаристы'); 
са, 
заро 24 П 
яс^ 


а ііпе 1 


а. 


Запись не была всилавлена, но РСУБД хомля бы 
снова реагирует на Ваши дейсилвия. 
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Апострофы КаК специальные символы 


сли вы вставляете в таблицу значение УАКСНАК, СНАК или ВІОВ, содержащее внутрен- 
ний апостроф, необходимо сообщить РСУБД, что этот апостроф не завершает текст, 

а наляется его частью и его необходимо включить в строку. Для этого можно поставить 
перед апострофом обратную косую черту. 


ІМЅЕКТ ТМТО ту сопіасізѕ 


(1осаф1оп) 
УАТОЕЗ 


('Гровер\' 


Аиосилро 

ЮУ тр ф Входиил В число < 
Рбированных» символов 
и^о означаеил, 


; 
(ниолняеил особые функции 


Он соодидаёил РСУБД, где 


начинаемся и зака 
фрагмени^ илексилА. 


. 
• Какие типы данных должны заклю- 
чаться в апострофы? 


} Текстовые типы данных — а проще 
говоря, значения УАБСНАВ, СНАК, 
ИГОВи ТТМЕРАТЕ. Короче, все, что не 
ипляется числом. 


: Нужны ли апострофы в столбцах 
ОЕС и ІМТ? 


} Нет. Числовые столбцы не содержат 
пробелов; РСУБД понимает, где кончает- 
‹ и число и начинается следующее слово 
п команде. 


за - 


$0. 
чило 6 языке он 


Милл'); 


\ Р 


нииваеился 


^ Частро 
задаваемые 


Весы 


. 
• Значит, апострофы используются 
только в текстовых столбцах? 


() Да. Проблема в том, что текстовые 
столбцы могут содержать пробелы. При 
наличии апострофов в данных это созда- 
ет проблемы. ЗСЕ не знает, как отличить 
внутренний апостроф в тексте от апо- 
строфа, начинающего или завершающего 
значение столбца. 


у меня нет 
пары, мне нужен 


Если 


. 

• А не проще различать их, заключая 
текстовые значения в кавычки вместо 
апострофов? 


(} Нет, не проще. Дело в том, что коман- 
ды ЗОСЕ позднее могут использоваться 

в языках программирования (например, 
РНР). В языке программирования кавыч- 
ки означают «здесь приводится команда 
$@Ё» — таким образом апострофы рас- 
познаются как часть команды $01, а не 
как часть конструкций языка программи- 
рования. 
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дальше » 


Команда ІМЅЕКТ с внутренним апострофом 


Вы должны сообщить РСУБД, что апостроф не обозначает начало 
или конец строки, а является частью текста. 


ЭКранироВание обратной Косой чертой 


Чтобы решить эту проблему (и одновременно испра» 
вить команду ТМ5ЕВТ), поставьте перед апострофом 


Ког : 
в тексте обратную косую черту: да бы сила ви иле перед 


алосилрофом префикс \, 
указыбающий, чило амо ~ 


ТМ5ЕВТ ІМТО пу сопіасіѕ силроф является часилью 
= илексила, эило называеился 
УАТОЕЗ <экранирование лм». ) 


('Фанион','Стив', ' ѕбеуе@опіопЁ1ауогейгіпдѕ, 
сот', 'М', '1970-01-04', 'Панк','Гровер\' Милл, 
МЈ','Не женат', 'Бунтарство','Единомышленники, 
гитаристы'); 


ЭКранироВание удоением апострофа 


Апостроф также можно «экранировать» другим способом — 
поставив перед НИМ дополнительный апостроф. 
Аиосилрофы илакже оса 


» идво- 
ТМЗЕВТ ІМТО ту сопёасіѕ но «экранироваиле» 4960 


ением, ило есиль заменои 


о одного алосмрофа двумя. 


/ 
('Фанион', 'Стив', ' зіеуеёопіоп 1ауогейгіпдз. / 
сот', 'М', '1970-01-04', 'Панк','Гровер'' Милл, 
МЈ','Не женат', 'Бунтарство' , 'Единомышленники, 
гитаристы'); 


0 мозговой 
ЎГШТУРМ 


С какими еще символами могут возникнуть анало- 
гичные проблемы? 
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Если таблица содержит данные с апострофами, вероятно, в какой-то момент вам потро 
буется искать их с условием НЕВЕ. Чтобы включить в выборку данные с апострофами, 
экранируйте их, как это делалось при вставке. 


Пражнение 


Перепишите следующую команду с использованием двух разных способов экранирова 
ния внутреннего апострофа. 


ЅЕТЕСТ * ЕВОМ ту сопіасізѕ 
ИНЕВЕ 
Іосаіоп = 'Гровер' Милл, М№Ј'; 


Какой способ вы предпочитаете? 


дағнлце в 103 


Если таблица содержит данные с апострофами, вероятно, в какой-то момент вам потре- 
буется искать их с условием НЕВЕ. Чтобы включить в выборку данные с апострофами, 
экранируйте их, как это делалось при вставке. 


пражнение 


3-5: Перепишите следующую команду с использованием двух разных способов экранирова- 
ния внутреннего апострофа. 


ЅЕТЕСТ * ЕВОМ ту сопіасіѕ 
ИНЕВЕ 
Іосаііоп = 'Гровер' Милл'; 


15 ЅЕГЕСТ * ЕКОМ илу_солёасіѕ 


Первый сљособ: одраилная 
\/МНЕКЕ 225 косая черила. 
он а ш 


( 
[осанои = А Милл, МЛ; 


127) ЅЕГЕСТ * ЕКОМ клу солЕас+ѕ 
Вилорой способ: удвоение 
У/НЕКЕ 27 апострофа 


п 
(осаћіои = 'Гровер Милл, МЛ; 
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Выборка ограниченного набора столбцов 


Итак, вы знаете, как написать команду ЗЕЪЕСТ для выборки любых 
гипов данных — в том числе и содержащих апострофы. 


Вывод ЅЕГЕСТ * получается слишком 
длинным. А если меня интересует толь- 
ко адрес электронной почты? Нельзя ли 
скрыть лишние столбцы? 


— М 


Команда $ЕТЕСТ может включить в выборку = 
только те столбцы, которые вам нужны. 

Чтобы с результатами было удобно работать, их 

нужно немного ограничить. Иначе говоря, выход- 

ные данные таблицы должны содержать меньшее 

количество столбцов — только те столбцы таблицы, 

которые нас интересуют. 


Попробуйте”сами 


Прежде чем вводить следующий запрос ѕЕІЕСТ, прикиньте, как будет выглядеть таблица 


Пражнение результатов. 


(Структура таблицы еаѕу агілкѕ показана на с. 93) 


Символ * заменяеился именами 


а силолбцов. М 
` к" 


ЅЕТЕСТ агіпк пате, таіп, зесопа 
ЕКОМ еаѕу агіпкѕ 


МНЕВЕ таїіп = 'содовая!; 


Запьше в 105 


выборка солнце 


Пепробуоте 


Прежде чем вводить следующий запрос $Е1ЕСТ, прикиньте, как будет выглядеть 
таблица результатов. 


пражнение 


Одинокое дерево содовая вишневый сок 
Борзая содовая грейпфрутовый сок 
Сода плюс содовая виноградный сок 


> При выводе Всех силолбиов резуль - 

Старый способ илаилы не помещаюился 8 окне илер - 
Е минала. Данные переносяился на 

ЅЕТЕСТ * ЕВОМ еаѕу Ягіпкѕ; следующую силроку и разобраилься 


8 них довольно сложно. 


Еіе Еак \УМпдом Нер МеѕѕуЮіѕріау 


> ЗЕШЕСТ * ЕВОМ еаѕу гіпкз; 


апооџпё1 зесопа атоцпЕ2 Я1хесЕ1оп$ 


| Поцелуй | вишневый сок я абрикосовый нектар| 7.00 | подавать 

со льдом и соломинкой | 

| Горячее золото | персиковый нектар | 3.0 | апельсиновый сок | 6.00 | влить в 
кружку горячий апельсиновый сок, добавить персиковый нектар | 

| Одинокое дерево | содовая | 1.5 | вишневый сок | 0.75 | взболтать 
со льдом, разлить по бокалам | 

| Ворзая | содовая | 1.5 | грейпфрутовый сок 5.00 подавать 
со льдом, тщательно взболтать 

| Бабье лето | яблочный сок | 2.0 | горячий чай 6.00 налить сок 
в кружку, добавить горячий чай | 

| Лягушка | холодный чай | 5 лимонад 500. подавать 
на льду с ломтиком лайма | 

| Сода плюс | содовая | и виноградный сок 1.00 взболтать 
в бокале, подавать без льда | 

| Терновник | тоник | 1.5 | ананасовый сок а | взболтать 
со льдом, разлить по бокалам, украсить лимонной цедрой і 

| Голубая луна | содовая | 1.5 | черничный сок | взболтать 
со льдом, разлить по бокалам, украсить лимонной цедрой | 

| Вот тебе на персиковый нектар | 1.0 | ананасовый сок я взболтать 
со льдом, разлить стаканам і 

| Лаймовый физз Й 1.5 лаймовый сок Я взболтать 
со льдом, разлить 


11 ромѕ іп зе (0.00 
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Отбор конкретных столбцов 


команда >: г: 


Указывая, какие столбцы должны возвращаться запросом, мы от- 
бираем из полных результатов интересующую нас информацию. 

По аналогии с тем, как условие МНЕВЕ ограничивает количество 
возвращаемых записей, конструкция отбора столбцов ограничивает 
количество возвращаемых столбцов. По сути, вы поручаете работу 


по отбору информации 801. 


А 
ЗЕЪЕСТ дгіпк пате, таіп, зесопа 


ЕКОМ еазу агіпкѕ; 


Ее Еди \ММпаом Нер ЈиѕіЕпоио 


Мы можем сузить 
резульглаиль: выдорки, 
включая В них илоль - 
ко инилересчющие нас 
силолдиы. 


ЗЕЪЕСТ ахг1пк пате, таіп, зесопа ЕВОМ еазу аг1пк$; 


агіпк пате | маіп 
вишневый сок 
персиковый нектар 
содовая 
содовая 
яблочный сок 
холодный чай 
содовая 
тоник 
содовая 
персиковый нектар 


Горячее золото 
Одинокое дерево 
Борзая 

Бабье лето 
Лягушка 

Сода плюс 
Терновник 
Голубая луна 
Вот тебе на 
Лаймовый физз 


11 гомз іп ѕеб (0.00 зес) 


| 
| 
| 
| 
| 
| 


ѕесопа 


абрикосовый нектар 
апельсиновый сок 
вишневый сок 
грейпфрутовый сок 
горячий чай 
лимонад 
виноградный сок 
ананасовый сок 
черничный сок 
ананасовый сок 


Отбор столбцов ускоряет получение результатов 


Отбор столбцов полезен и удобен, но у него есть и другие 
преимущества. С увеличением объема данных в таблице отбор 
столбцов ускоряет получение результатов. Ускорение проявляет- 
ся и при использовании кода 501 в других языках программиро- 


вания, например РНР. 
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возьми в руку карандаш 


Возьми в руку карандаш 


< 


Несколько способов получить «Поцелуй» 


Помните нашу таблицу еаѕу агіпкѕ? Следующая команда 
ЗЕЪЕСТ вернет коктейль «Поцелуй»: 


ы. 


ЅЕТЕСТ агіпк паме ЕВОМ еазу дгіпкѕ 
МУНЕВЕ 


паіп = 'вишневый сок'; 


Допишите четыре команды ЗЕТЪЕСТ на следующей странице, чтобы они тоже воз- 
вращали «Поцелуй». 


еаѕу йгіпкѕ 


взболтать со льдом, разлить по бока- 


Терновник тоник 1.5 ананасовый 
сок лам, украсить лимонной цедрой 
Голубая луна содовая 1 черничный сок 0:75 взболтать со льдом, разлить по бока- 
лам, украсить лимонной цедрой 
Вот тебе на | персиковый ананасовый 1 взболтать со льдом, 
нектар сок разлить по стаканам 
Лаймовый Спрайт сок лайма 0.75 взболтать со льдом, 
физз разлить по бокалам 
Поцелуй вишневый 2 абрикосовый 7 подавать со льдом и соломинкой 
сок нектар 
Горячее персиковый Е апельсиновый влить в кружку горячий апельсино- 
золото нектар сок вый сок, добавить персиковый нектар 


Одинокое содовая вишневый сок 0.75 взболтать со льдом, 
дерево разлить по бокалам 
Борзая содовая грейпфруто- 5 подавать со льдом, 
ВЫЙ СОК тщательно взболтать 
Бабье лето яблочный горячий чай налить сок в кружку, 
сок добавить горячий чай 
Лягушка ХОЛОДНЫЙ 5 подавать на льду с ломтиком лайма 
чай 
Сода плюс содовая 1 взболтать в бокале, подавать без льда 


5 
г | 
аф 
ке) 
я 2| © 
ны 
т [87] 
с ъч 
= 
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команда ЗЕЕЕСТ 


Теперь запишите три команды ЅЕТІЕСТ, которые возвращают коктейль «Лягуш- 
ка». 


сагы + 109 


возьми в руку карандаш. решение 


«Возьми в руку карандаш 
`` “ОШРНИС Допишите четыре команды ЗЕТЕСТ на следующей странице, чтобы они 
"к тоже возвращали «Поцелуй». 

ЗЕЪЕСТ ФИК лаиле РЕКОМ ёаѕу дейт 

МНЕВЕ ѕесоиа = ‘абрикосовый некилар; 1... 
ЗЕГЕСТ дкі маиле ЕРОМ сау дає 

НЕВЕ  ПИОЦИЇ2 = 7; ила 

ЗЕШЕСТ алк мамле ЕКОМ еаѕу аи... 

МНЕВЕ огесной$ = 'лодаваиль со льдом и соломинкой"; 


Эма форма всилречаеил - 
ся редко. Исиользуйиле ее, 


а если вы иолносилью 9ве- 
МНЕВЕ ЯтиК_патле = ‘Поцелуй’; РЫ в илом, чило о 
О И Е и ЯгтлК_паиле записан без 
оилибок. 


Теперь запишите три команды ЅЕТЕСТ, которые возвращают коктейль «Лягуш- 
ка». 


& ЅЕГЕСТ дек маиле ЕКОМ еаѕу дгіміѕ 
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КЛЮЧЕВЫЕ 
МОМЕНТЫ 


ш Используйте апострофы в условии 
М/НЕВЕ при ссылке на значения 
текстовых столбцов. 


в Не используйте апострофы при ссыл- 
ке на значения числовых столбцов. 


а Используйте * в команде 5ЕТЕСТ для 
выборки всех столбцов таблицы. 


команда 5Е: ЕСГ 


ш Если вы ввели запрос, а РСУБД 
не может завершить его обработку, 
проверьте, нет ли в нем непарных 
апострофов. 


в По возможности используйте выборку 
конкретных столбцов таблицы (вме- 
сто конструкции ЗЕТЕСТ *, включащей 
все столбцы). 


часто 


адаВаеМые 


Волфа 


: А если запрос должен вернуть все столбцы таблицы? 
еречислять их в ЗЕЪЕСТ или использовать * ? 


(} Если вам действительно нужны все столбцы — конечно, ис- 
пользуйте *. Перечисление столбцов хорошо работает только тог- 
да, когда вас интересует ограниченное подмножество столбцов. 


О 

* Я скопировал запрос из Интернета, но когда пытаюсь 
выполнить его на своем компьютере — происходит ошибка. 
Я делаю что-то не так? 


(} Запросы, вставленные из браузера, часто содержат невиди- 
мые символы, внешне неотличимые от пробелов, но имеющие 


другой смысл для 501. Вставка в текстовый редактор — один из 
способов выявления и удаления символов-«невидимок». Так что 
В подобных ситуациях лучше всего вставить запрос в текстовый 
редактор и повнимательнее присмотреться к нему. 


0: Например, в Місгоѕоћ Мога? 


() Нет, Мога — не лучший вариант. Эта программа не показы- 
вает скрытое форматирование, которое может присутствовать 
в тексте. Попробуйте использовать Блокнот (РС) или ТехіЕаїќ 

в режиме простого текста (Мас). 


ммм, пончики... 


Пончики и таблицы... 


Чтобы найти в таблице лучшие пончики с глазурью, нам понадо- 
бятся минимум две команды ЗЕТЕСТ. Первая выбирает записи 
с пончиками нужного типа, а вторая — записи с оценкой 10. 


Хочу 
лучшие пончики с глазурью, 

и побыстрее — не хочу копаться 
в сотнях записей. 


доцдћпоё гаёіпдѕ 


Зафу?2 Сойее ЕИ 23/4 с корицей 
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СЛИШКОМ МНОГО 
пряностей 


Е 

7:43 &= 

ЕЕ ЕЕК ВЕ ВЕНЕРА ЕСЕД Кети 

ГИ 29 | №7 | скины [6 | ТИ 
„ с глазуры АВА | 


Кизру Кіпо 056 | 2 
“ии 
Предсилавьте, чило иладлиц 


содержиил 10 ООО записей. 


еновый сироп 


ГЕ] Можно провести поиск по типу пончиков: 
В выдорку вклкчасился силолдец 


гайи4 для поиска Высшей оценки, 
Ра а илакже силолбец (осаёіои с на- 
званием заведения. 
ЅЕГЕСТ 1осаёіоп, габіпд ЕКОМ доџдһпоё гаііпдз 
МНЕВЕ 


ь о о ве Все Выбранные записи ӧудуил 
— имемль нужное значение чре. 


1осаНоп 


вв 
РЕГБИ ВЕЕТ 
ЕЯ 


опсап'ѕ Ояпоћ 
“> 


Результлаилы первого 
запроса... Предсилавьме, 
чило дальше идуил еще 
несколько соилен записей. 
ү 
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команда 5ЕЕЕСТ 


...Таблицы и пончики 


12) А можно выполнить поиск по оценке: 


ЅЕТЕСТ 1Іосаёіоп, ёуре ЕВОМ аоцдһпоё габіпдзѕ 


ЯНЕВЕ к м 
і Ау В выборку включается силолбец 
Арева: — фуре для проверки илила, а макт 
же силолбец осанои. с названием 
заведения. 


Все Выдранные записи 
именил Высшую оценку. 


Оупсопд Боди 2] 


Вилорой запрос снова 
возвращаеил соилни 


< записей. 


Маловато пользы от таких запро- 
сов. Я могу выбрать любой из двух вариантов 
и перерыть результаты, но в таблице многие 
тысячи записей... А я хочу пончик 
прямо сейчас! 


‚с мозговой 
ОШТУРМ 


На какой вопрос мы хотим получить ответ 
в этих запросах? 


дальше + 113 


объединение усло ': 


Объединение условий 


Два условия поиска — тип «с глазурью» и оценка 10 — 
можно объединить в один запрос при помощи ключево- 
го слова АМР. Результаты такого запроса будут удовлет- 
ворять обоим условиям. 


Телерь досилаим^очно вВыдраиль 


ЗЕБЕСТ Тоса+1оп”_ илолько силолбец осаои. 
ЕВОМ аопарпае габіпдѕ 
МНЕВЕ буре = 'с глазурью' 


Ключевое Сл 
——— - ` слово АМР | 
АМО < два условия М/НЕБЕ. объединяеии 


капа = 10; < 


Результат запроса АМР”. Даже если запрос вернет 
несколько записей, мы будем знать, что во всех этих 
заведениях есть глазированные пончики с оценкой 10, 
так что пойти можно в любое из них. Или во все 
поочередно. 


Заирое объединяеил резульилаиль: 
выборки по условиям «с глазурью» 
и оценкой 10 и накодиил записи, 
удовлеилворяющие обоим условиям. 


Загри77 СоНее 


Бупсап'$ Воп\$ 


Ѕіагрџо22 Сойее 
Кгіѕру Кіпа 


Эагру?2 СоНее 


танно | 
ЕС 


10 


Мама, 
пойдем в Ѕ5їагЬи22? 
Ну пожааалуйста?! 


ЅагЬу2 Се 
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команда <: г:. : 


Так значит, я мог найти 
Энн при помощи АМО? 


ражнение 


Используя таблицу му сопіас+ѕ, напишите несколько запросов для 
Грега. Включите в выборку только те столбцы, которые необходимы для 
получения ответа. Обратите особое внимание на апострофы. 


Напишите запрос для получения адресов электронной почты всех про- 
граммистов. 


Напишите запрос для получения имени и места жительства всех людей, 
у которых дата рождения совпадает с вашей. 


Напишите запрос, при помощи которого Грег мог бы найти всех Энн из Сан-Франциско. 


дальше + 115 


упражнение. решение 


Используя таблицу ту сопіасіѕ, напишите несколько запросов для Грега. Включите 


в выборку только те столбцы, которые необходимы для получения ответа. Обратите особое 
пр ажнение внимание на апострофы. 


пече рл 
Рение 


Напишите запрос для получения адресов электронной почты всех программистов. 
Нам нужен | 
силолбец виа! < 


О оооло оао ОА асаа ааа ааа адата таа аа ааа атаа ага 


. авно ‘программиси^". 
Напишите запрос для получения имени и места жительства всех людей, Р а 


у которых дата рождения совпадает с вашей. 


а Здесь должна быиль 


Ваша дарила рождения. 


Напишите запрос, при помощи которого Грег мог бы найти всех Энн из Сан-Франциско. 


ЅЕІЕСТ [а5Е мамле, ЁЁ маиле, вила 
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команда 5Е1ЕСТ 


Поиск числовых значений 


Предположим, вы хотите найти в таблице еаѕу гіпкѕ все напит- 
ки, содержащие более одной унции содовой, и сделать это в одном 
запросе. Сложное решение с двумя запросами выглядит так: 


Нам нужны назва ы, 
н 
ия Найиилков. / ЗЕЪЕСТ бгіпк папе ЕВОМ еазу дгіпкз 


ИНЕВЕ 
ки, Е 
о >” таіп = 'содовая' 
р АМР 


1,5 унции содовой. 
`—> амоцпЕ1 = 1.5; 


> ЗЕЦЕСТ агіпк пате ЕВОМ еаѕу дгіпкѕ МИНЕКЕ шаіп = 'содовая' АМО 
атоцпё1 = 1.5; 
+ 


| дгіпк пате 


Да 
Голубая луна 
Одинокое дерево 
Борзая 


гомѕ іп ѕеі (0.00 ѕес) 


ЅЕГЕСТ агіпк паше ЕВОМ еазу агіпкѕ 
Наицилки, > УНЕВЕ 
содержащие шаіп = 'содовая' 
2 унции содовой. АМО 


М гюњоцпё1 = 2; 


> ЅЕІЕСТ агіпк пате ЕКОМ еаѕу дгіпкѕ МНЕВЕ таіп = ‘содовая' АМ 
атоцпіі = 

+ 

| агілк паме 

ке 

| Сода плюс | 

+ —+ 


1 гоч іп ѕе (0.00 ѕес) 


дальше » 117 


операторы сағ -:.. · 


А как было бы здорово, если 
бы в одном запросе можно было най- 
ти все напитки из таблицы еазу_агпК$, 
содержащие более 1 унции содовой... 
Но я знаю, что это всего лишь мечты... 


Терновник тоник 1.5 ананасовый 1 взболтать со льдом, разлить по бокалам, 
сок украсить лимонной цедрой 
Голубая луна содовая 182 черничный 0.75 взболтать со льдом, разлить по бокалам, 
сок украсить лимонной цедрой 
Вот тебе на персиковый ананасовый 1 взболтать со льдом, разлить по стаканам 
нектар сок 


Лаймовый физз Спрайт 1.5 сок лайма взболтать со льдом, разлить по бокалам 


подавать со льдом и соломинкой 
Горячее золото персиковый 3 апельсино- влить в кружку горячий апельсиновый сок, 
нектар вый сок добавить персиковый нектар 
Борзая содовая 1.5 грейпфруто- 5 подавать со льдом, тщательно взболтать 
вый сок 


взболтать со льдом, разлить по бокалам 
налить сок в кружку, добавить горячий чай 
Лягушка холодный чай | 15 | лимонад | подавать на льду с ломтиком лайма 
Сода плюс содовая 2 виноград- взболтать в бокале, подавать без льда 
ный сок 
118 раза 2 


команда 3... 


Одного достаточно 


Однако использовать два запроса вместо одного неэффективно; 

к тому же вы рискуете упустить напитки, в которые входит 1.75 или 
З унции содовой. Лучше воспользоваться оператором сравнения 
«больше»: 


ИНЕРЕ 
паіп = 'содовая' 


[——С операилором > эмо условие 
вернеил все налиилки, содержащие 


ип 1 (>) 1; более 1. унции содовой. 


| Еіе Еа Миадом Нер рокОпсе 
> ЅЕГЕСТ агіпк паме ЕВОМ еазу агіпкѕ МИНЕКЕ таіп = 'содовая' АМ 


аюмоцпі1 > 1; 


агіпк паме 
Толубая луна 
Одинокое дерево 
Борзая 

Сода плюс 


гомѕ іп ѕе (0.00 ѕес) 


с мозговой 
СУШТУРМ 


А почему первые два запроса нельзя объединить дополнитель- 
ным оператором Амр? 


Өзлоне { 
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подробнее об операторах сравнения 


Операторы сравнения 


Ранее в наших условиях ИНЕКЕ использовался только 
оператор =. Вы только что увидели пример исполь- 

зования оператора >, сравнивающего одно значение 
с другим. Ниже приведена полная сводка операторов 


сравнения. 

Оператор = проверяет только точные совпаде- Этот странный знак означает «не равно». Его 
ния. Он не поможет, если вы хотите проверить, результат прямо противоположен результату 
что некоторое значение меньше или больше знака =. Два значения либо равны, либо не 
другого. равны — третьего не дано. 


Всем извесилный знак Означаеил «Н 


ЕР 
равенсилва. возврашщаеул АВНО»>. Условие 


все запис 
и, Ч комлорых 
а значения не совладакоил. о 


2 мозговой 
"ШТУРМ 


А вы заметили, что в каждом рассмотренном нами условии ИНЕВЕ 
имя столбца располагалось слева? Будет ли условие работать, 


если имя столбца будет указано справа? 


Оператор «меньше» сравнивает значение 
столбца, указанного слева, со значением 

в правой части. Если значение столбца 
меньше, то запись включается в возвра- 
щаемый набор. 


команда ЗЕГЕСТ 


Оператор «больше» по смыслу противополо- 
жен знаку «меньше». Он сравнивает значение 
столбца со значением в правой части. Если 
значение столбца больше, то запись включается 
в возвращаемый набор. 


Оператор «меньше» 


и 


ес 


Оператор «меньше или равно» отличается 

от «меньше» только одним: столбцы, значение 
которых равно заданному, тоже включаются 

в результат. 


Возвращанился все записи со значением 
силолбиа, МЕНЬШИМ ИЛИ РАВНЫМ 
заданному. 


возвраидаеил все значения, 
„^ Меньщие заданного. 


И конечно, сущесилви - 
еил парный олераилор 
«больше». 


„= 


То же и с оператором «больше или равно». 
Если значение столбца больше заданного 
значения или равно ему, то запись включа- 
ется в возвращаемый набор. 


Операило 
БОЛЬШЕ или РАВНО. 


дальше » 121 


ищем числовые данные 


Операторы сравнения при поиске числовых данных 


В баре хранится таблица с ценами и данными о калорийности напитков. Владелец 
хочет отобрать напитки с высокой ценой и низкой калорийностью для проведения 
рекламной акции. 


При помощи операторов сравнения он ищет в таблице Ат1пк_1п2о напитки с це- 
ной более $3.50, содержащие не более 50 калорий. 


122 


Количесилво углеводов 


; \ 
(6 граммах). хо  КаЛорийносиль 


агіпк іпЁо / е 


_ ані вате | сәз | сагыз © | сое | №е | сене 
Терновник | з | ва | желй | д Ш 

__Голубаялуна 1 25 | 321 сми [д | 
55 
321 


4 г | д 
| ШЕЕ 
Са ласти я |8 
7 ЕП 
Е 
7 


а Й 
н 


ЕІЕСТ агіпк паме ЕКОМ агіпк іпѓёо 


ВЕ Эило значиил: <Напиилки с ценой 


<= 35.50 и б 
соз >= 3.5 а ее: Схода бходаил 
и, силоящие ровно $3.50. 
АМО 
2 А Эило значиил: «Напитки, с0 
сарона. 225868 держащие менее 50 калорий». 


Запрос возвращает только напитки, удовлетворяющие обоим усло- 
виям — потому что два результата объединяются ключевым словом 

АМО. Запрос возвращает напитки «Вот тебе на», «Одинокое дерево» 
и «Сода плюс». 


лава 2 


команда < ЕСТ 


«Возьми в руку карандаш 
А теперь ваша очередь. Напишите запросы, которые возвращают ука- 
ы. занную информацию. Также запишите результат каждого запроса. 


Цены желтых напитков со льдом, содержащих более 
33 калорий. 


Названия и цвета напитков, содержащих не более 4 граммов 
углеводов, в которые кладется лед. 


Результат: аиа ААЛУ а ОА Раа ыу 


Цены напитков, содежащих 80 и более калорий. 


РОЗОВОЕ аа 


Напитки «Борзая» и «Поцелуй», с цветом и информацией об использова- 
нии льда, но без указания названий напитков в запросе! 


И И 


резные а 123 


возми в руку карандаш. решение 
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Возьми в руку карандаш 


ы, Решение А теперь ваша очередь. Напишите запросы, которые возвращают ука- 


ы. занную информацию. Также запишите результат каждого запроса. 


Цены желтых напитков со льдом, содержащих более 


33 калорий. : | 
Е ВЕ ЗЕНЕСТ,. с05 РВОМ К. 


Названия и цвета напитков, содержащих не более 4 граммов 
углеводов, в которые кладется лед. 


ЅЕІЕСТ ЯАилК_паиле, соог ЕВОМ акик иЮ 


Цены напитков, содежащих 80 и более калорий. 


бы ЅЕГЕСТ соѕ РЕКОМ дик 

Но ведь это работает только 

с числами, верно? А если мне 
понадобится найти все напит- 
ки, названия которых начина- 


ются с конкретной буквы? 


Напитки «Борзая» и «Поцелуй», с цветом и информацией об исполь- 
зовании льда, но без указания названий напитков в запросе! 


ЗЕГЕСТ дниК_паиле, соо, ісе ЕВОМ аилКиЮ 


ооо ооо ото ов обе Хитрый воирос... Вы 


СО5 >= 5.8; “ 
О е ОЕА должны были иросмои ~ 
Ем реиль иладлицц и найили \ 
ИЕ ИЕ АЕ, силолдец, по коилорому 

Поцелуй, фиолеиловый, Д Можно было бы оилобраиль 


Результат: Борзая, желилей, Д ЗИЛИ —— и ИлОлЬко зили! — 
ОЧА е ПАГ 


глава 2 


команда ЅЕ ЕСТ 


Операторы сравнения при поиске текстовых данных 


Сравнение дапных текстовых столбцов (СНАВ и УАКСНАК) происходит аналогич- 
ным образом. Операторы сравнивают значения в алфавитном порядке. Допу- 
стим, вас интересуют все напитки, названия которых начинаются с буквы «Г»; 
следующий запрос выбирает напитки, удовлетворяющие этому критерию. 


агіпк іпёо 


= | әв Гә | 
А 
78 
Е 


Лаймовый физз 
Поцелуй фиолетовый 

Одинокое дерево] 35 | 42 | красный | Д | 
оран | 4 | м | елын | Д | 
Бабье лето 
Ляуша | 25 | 25 | боны [д | №0 | 


 «аіепез | 


ЅЕІЕСТ агіпк пате 
ЕКОМ агіпк 1пЕо 


УНЕВЕ 
ани: ыы Запрос возвращаем налиилки, 
АМР” начинающиеся с буквы Г и следу 


і апе "т! . ющих букв, но при эилом первая 
и «Бае < буква предшесилвуеил Д. 


РАССЛАБЬТЕСЬ Пока не беспокойтесь о порядке 


„Л 


—> следования записей в результатах. 


В следующей главе вы узнаете, как отсортировать резуль 
таты по алфавиту. 


это “ли то 


Выбор ингредиентов 


Бармена попросили сделать коктейль с вишневым соком. Для по- 
иска рецептов можно воспользоваться двумя запросами. 


Ре ЕЯ УМпдом Нер.. 


т 'вишневый сок’; 


Лос запроса аациицициици 

для проверки 
водого и вило- 

рего ингреди- 


снимая 


гом іп ѕеё (0.02 зес) 


ЅЕРЕСТ дгіпк пате ЕВОМ еаѕу дгіпкѕ ИНЕКЕ ѕесопа = ' вишневый сок'; 
+ 
агіпк пате | 
-- + 


Одинокое дерево | 


гом іп ѕе (0.01 ѕес) 

Два запроса? Неэффективно. 

Наверняка их можно как- 
нибудь объединить. 


агіпк іпёо 


7 


1 


голубая лун з 


[ке | 

д | 

[32 | т 

[Воттебена_|_35 | 86 | оранжевый | Д | 

_Лаймовый физ | 25 | 54| зеленый | Д | 
[поцелуй | 55 | 425 | фиолетовый [д | тт 

| а 

д | 

та 

7 Еа 

Д | 


вонам | жетъй 
 ваљело | 28 | 22  [ ричневый [ # 
солат [38 |а | май [НЮ | 


команда 55:6? 


Быть ЦЛЬ не быть 


Для объединения двух запросов используется связка ОК. С этим условием запрос 
возвращает записи, у которых выполняется любое из указанных условий. Таким 
образом, из двух отдельных запросов строится один комбинированный запрос. 


ИНЕВЕ таіп = 'вишневый сок' 
Ов 

ѕесопа = !' вишневый сок'; 

+. --- - - А 


| агіпк пате 


| 
+ Е 


| Поцелуй | 
Одинокое дерево | 


2 комѕ іп ѕеё (0.02 ѕес) 


е, Возьми в руку карандаш 


ч Вычеркните лишние части двух команд ЗЕТЕСТ и добавьте 
є. связку ОК, чтобы превратить их в одну команду ЗЕТЕСТ: 


ЗЕБЕСТ агіпк пате РВОМ еазу йгіпкѕ ИНЕВЕ 
паіп = 'апельсиновый сок'; 


ЗЕТЪЕСТ агіпк пате ЕКОМ еаѕу йгіпкѕ ИНЕВЕ 


тазп = 'яблочный сок'!; 


Запишите здесь полученную команду ЗЕЪЕСТ. 
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еще один отвеп: 


„ Возьми в руку карандаш 
гешение 


Вычеркните лишние части двух команд ЅЕІЕСТ и добавьте 


мц, связку ОК, чтобы превратить их в одну команду 5ЕІЕСТ. 


ЅЕІЕСТ агіпк пате ЕВОМ еазу агіпкѕ ИНЕВЕ РИ 

1 ' Ба 57 т <.» нужно У2ра/^?, 

шаіп = 'апельсиновый сок' АА о оемАНВА еще 
не завершена. 


паіп = 'яблочный сок'; 


Со связкой О 


лросило 
Эилч мроку можно р 
р РА Заиро 6 он с 
названия Нам. С єрне 


необходи - 
Вычеркнуило, все не 
Мч иилков, глав моё р 8 первой часили 
яВляемс дненлом Которых зайроса (присоединенной 
а синовый 28). 
Яблочный сок. й ИЛИ ключевым словом ОК) 


Запишите здесь полученную команду ЅЕІЕСТ. 


ЅЕГЕСТ дитК_паиле ЕКОМ еазч_4ииК$ 
У/НЕКЕ 

маи = ‘апельсиновый сок! 

ОЕ 


, . Запрос С 
ила. = ‘яблочный сок"; а Рос, который 
9 нас получился. 
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команда ЗЕЕЕСТ 


Оператор ОВ действительно 
полезен, но я не понимаю, поче- 
му мы не воспользовались АМО? 


Не путайте АМО с ОК! 
Если истинными должны быть ВСЕ условия, исполь- 


зуйте АМОР. 


Если истинным должно быть ХОТЯ БЫ ОДНО 
из условий, используйте ОВ. 


Так и не разобрались? Переверните страницу. 


АМО ОВ 


п) 
задаВаеМые 


Воть Сы 


‚ Можно ли использовать более одной 
связки АМР или ОВ в одном условии 
УНЕВЕ? 


. 

0); Конечно, связок может быть сколько 
угодно. Также в одном условии АМР” может 
использоваться вместе с ОВ. 
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АМО :7:: ОР? 


Чем АМО отличается от ОВ 


Следующие примеры демонстрируют возможные комби- 
пации двух условий, объединенных связками АМр и ОК. 


доцдћпиё гаііпдѕ 


[Пьяные | 


Ѕїагби22 СоНее 19:35 24/5 


ЗЕТЕСТ Еуре ЕВОМ ЧЗочдрпае габіпдѕ 


Ы Да 
Да, есиль совладение 
С ЕЕК Ри 


ИНЕВЕ 1осаёіоп = 'Кг1зру Кіпд' АМР габіпд = 10; 


МНЕВЕ 1осаёіоп = 'Кг1зру К1пд' ОВ габіпд = 10; 


габ У“ 
МНЕВЕ 1осаёіоп = 'Кгізру Кіпд' АМО гаіпд = 3; 


ИНЕБЕ 1осабіоп = 'Кг1зру Кіпд' ОВ габіпд = 3; 


Неил совладений 


МНЕВЕ 1осаёіоп = 'Ѕпарру Ваде1' АМО габіпд = 10; 


МНЕВЕ 1осаёіоп = !Ѕпарру Ваде1' ОВ гаїіпд = 10; 


1 
ш 


МНЕКЕ 1осаёіоп = 'бпарру Ваде1' АМО гаїіпд 


1 
о 


ИНЕВЕ 1осаііоп = 'бпарру Ваде1' ОВ гаііпд 
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тенир | 
_ Оипсапѕ опи | 859 | 25/8 | ми | 6 | жирноваты | 


вчерашние, но вкусные 


мало варенья 


Неил З, 
и, совладений 


РЕЗУЛЬТАТЫ 


с глазурью 


с глазурью 


нет 


с глазурью 


нет 


с глазурью 


нет 


нет 


команда ЗЕЕЕСТ 


СТ АТ ЧсЛоВием 


\ [еже приведена серия ЦсЛеВий 
г со сВвязкамч АХ = (К. -съавьте себя на 


Местро этрих ЧсЛоВий и определитре, КаКой Ре- 
ЗУЛьтрата вернут тракие запросы, 


ЗЕТЕСТ буре ЕВОМ аочарпаЕ га+1п9$ Результат: 
ИНЕВЕ 1осабіоп = 'Кұізру Кіпд' АМО гаібіпд <> 6; 
МИНЕКЕ 1осаііоп = 'Кгізру Кіпд' АМО гаёіпд = 3; 
НЕВЕ 1осабіоп = 'бпарру Ваде1' АМО гаііпд >= 6; 

МНЕВЕ 1осаЕ1оп = 'Кгізру Кіпд' ОВ гаііпд > 5; 


МНЕВЕ 1осабіоп = 'Кгіѕру Кіпд' ОВ гаііпд = 


ҸНЕКЕ 1осаііоп = 'бпарру Ваде1' ОВ гаііпд = 6; 


Для улучшения сВоей каРМы напиШитре, чем дВа 


Рез4Льтратра отрЛичаютрся отр остраЛьных, 
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условия. ответ 


СТАП а (оветр 


Ше приведена серчя условий МҮ 


со связками А (В. [-соавьте ни 


на Местре этпих ЧсЛеВий и опредеЛитре, 
какой резуЛьтрато Вернут 
тракче запросы. 


ЅЕТЕСТ суре ЕКОМ аочадрпа® гаїіпдѕ 


ИНЕВЕ Іосаііоп = 'Кгізру Кіпд' АМР гаїіпд <> 6; 


ИНЕВЕ Іосабіоп = 'Кг1зру Кіпд' АМ0 гаїіпд = 3; 


МНЕВЕ 1осаёіоп = 'Ѕпарру Ваде1' АМ0 гаїіпд >= 6; 
МНЕВЕ 1осаёіоп = 'Кгізру Кіпд' ОВ гаїіпд > 5; 
МНЕВЕ 1Іосабіоп = 'Кгіѕру Кіпд' ОВ гаїіпд = 3; 


МНЕВЕ 1осаіоп 


"Ѕпарру Ваде1' ОВ гаііпд = 6; 


Пля улучшения сВоей каРМы напишитре, Чем дВа РезуУЛьтратра 


отпЛиЧаютрся отр остаЛьных, 


Два запроса Возвраиҳщаюи МОШ. 


Результат: 


с глазурью 


Эти значения МОБ могут создать проблемы в будущих запросах. В столбце табли- 
цы лучше ввести какое-либо определенное значение, чем оставлять в нем МОТЬ, 


потому что прямая выборка МОЛ, из таблицы невозможна. 
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команда ЗЕЕЕСТ 


ЦепользоВание |$ МИЦ. для поиска МИЦ. 


—А асас Р 
пытался выполнить поиск по столбцам, содер- 
жащим МОШ, но у меня ничего не получилось. Как 
найти МОЦ. в таблице? 


бо 


агіпк іпёо 


ЕТ [и [ че | 
миг лоп 


Прямая выборка МУ невозможна. Однако МОШ можно найти 
при помощи ключевых слов. 


ЅЕГЕСТ агіпк пате ЕВОМ агіпк іпёо 


ТЕРЕ М Не работаем, е 
авно 
са1огіез =н. никакое значение не р | 
а мош. — неопределенному ЅЕТЕСТ агіпк пате 
значению. ЕВОМ Агапк іпёо 
ЗЕТЕСТ агіпк пате ЕВОМ аглоКк 1пЕо ИНЕ ——_ 
МНЕКЕ ЕЕ рб А дЕ и Прямая Выборка 
Р рае МЕ са1огіеѕ 13 МОЦ; значений МУН 
сазогаез Ж и НУЛЬ — это разные возможна илолеко 
а Ключевые слова — с И 
не иле; а. чевых сло 
ЅЕШЕСТ Згіпк папе ЕВОМ агіпк іпёо е К дан а м 
ы Е 2 аклю ~ . 
ИНЕВЕ Тоже не рабоилаетл, МОШ. — цаюился в ем 
саїогіеѕ = '\ 7 не являеился илексиловой , 
силрокой. 
= Часто 
Задаваемые 


Восы 


В: Вы говорите, что «прямая выборка» МОТ, невозможна 0: И как будет выглядеть результат этого запроса? 

без использования 15 МОШ.. Значит, возможна, непрямая? ( 

| |} Он будет выглядеть так: 
• Верно. Если вы хотите получить значение из этого столбца, 


можно воспользоваться условием НЕВЕ для других столбцов. а + 
Например, следующий запрос вернет МОТ.Т:: | са1огіеѕ | 
ЗЕЬЕСТ са1ог1ез ҒКОМ дгіпк 1пЕо Еее + 
МНЕВЕ Ах1пКк пате = 'Дыхание дракона’; | МО, | 

+----------- + 
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однообразные запросы 


Тем Временем В доме Грега... 


Грег пытается найти в таблице ту сопсасіѕ всех 
людей, живущих в Калифорнии. Часть запроса, над 


которым он работает, выглядит так: 


Набирать все эти 
ОВ так утомительно! 


ЗЕЦЕСТ * 
УНЕВЕ 
1осаёіоп 
ОВ 
1осаііоп 
ОВ 
1осаііоп 
ОВ 
1Іосаёіоп 
ОВ 
1осаёіоп 
ОВ 
Іосаііоп 
ОВ 
Іосаїіоп 
ОВ 
Іосаііоп 
[97-4 
1осаііоп 
ОВ 


ЕКОМ ту сопбасіѕ 

= ‘Сан-Франциско, СА' 
= 'Сан-Хосе, СА' 

= 'Сан-Матео, СА' 

= 'Саннивейл, СА' 

= 'Марин, СА' 

= 'Окленд, СА' 

= 'Пало-Альто, СА' 


= 'Сакраменто, СА' 


= 'Лос-Анджелес, СА' 


И так далее... 


ШКЕ: слово для экономии Времени 


В Калифорнии слишком много городов. Если Грег 
попытается перечислить их все в запросе, объединяя 
связкой ОВ, это займет у него слишком много времени. 
К счастью, существует полезное ключевое слово ГТКЕ, 
которое в сочетании со специальными символами ищет 
часть текстовой строки и возвращает совпадения. 


Грег может использовать .ТКЕ следующим образом: 


ЅЕТЕСТ * РЕКОМ ту сопіасіѕ 
ИНЕВЕ 1осаііоп 1ІКЕ '%СА'!; 


не. 


(Специальные символы 


ТІКЕ обычно используется в сочетании с двумя спе- 
циальными символами — «заместителями», которые 
представляют фактическое содержимое строки. 
Специальные символы, словно джокер в карточных 
играх, равны любому символу (или последователь- 
ности символов) строки. 


© мезговой 
ШТУРМ 


Какие еще специальные символы 
встречались вам в этой главе? 


команда 5Е1 ЕСТ 


Знак % в алосилрофах 
Оказыбаеил ващей иро - 
гРамме, чило Вас ин 
илеРесуюил все значения 
силолдиа Іоса+ѓои, ко 
илорые заканчиваюился 
сокращением «СА». 
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ЫКЕ и специальные символы 


Я ШКЕ это 


ТІКЕ используется со специальными симво- 
лами. Первый — знак % — обозначает любое 
количество произвольных символов. 


ЅЕТЕСТ ЁҒігѕ пате ЕВОМ ту сопфас®5 
МНЕВЕ Ғірѕё пате ГТКЕ '%им'; 


О ~ Предсилавляеи^ любое_количе - 


силво неизвесилных символов. Запрос возвращаеил име- 
на, коилорые сосилояил из 
любого количесилва сим- 
волов и заканчиваюился на 


<иЛл> — Эфраим, Джим, 
Тим и и. д. 


Второй специальный символ, так часто 
встречающийся в компании Г.ТКЕ, — знак 
подчеркивания (_) — представляет ровно 
один произвольный символ. 


ЅЕТЕСТ Е1г5® пате ЕКОМ ту сопфас*з 


МНЕРКЕ Ғігѕб пате 1ІКЕ '_им'; 
И“ Заме 6 Е Ы 
РА КЫР и ОРАЕ произволь- Запрос возвращает 


м 2а имена, коилорые сот 


силояйл из одной буквы 
и «им» — Ким, Тим 


и и. д. 
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команда ЅЕ1ЕСТ 


Магнихоь: с Кодами 


Условия ИНЕВЕ с ключевым словом ГТКЕ и их результаты 
полностью перепутались. Сможете ли вы восстановить соответ- 
ствие? Некоторые условия могут возвращать несколько резуль- 
татов. Напишите собственные условия ГТКЕ со специальными 
символами для лишних результатов. 


НЕВЕ засе ТЛКЕ 'Нью-%'; 


ИНЕВЕ сом _паще ІІКЕ ' си’; 


НЕКЕ +1%]е ІІКЕ '501%'; 


ИНЕВЕ ЕРуше_ мога ІІкЕ "Фендер; 


и Ва а 
| З9Г. для начинающих } 


- Стрелка 


аше 1ІКЕ 'Джо%'; 


УНЕРЕ Ғігзі п 
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решение с магнитами 


Магнихоы с КодамМи 


Условия ИНЕКЕ с ключевым словом ГТКЕ и их результаты 
полностью перепутались. Сможете ли вы восстановить соответ- 
ствие? Некоторые условия могут возвращать несколько резуль- 
татов. Напишите собственные условия І.ІКЕ со специальными 
символами для лишних результатов. 


НЕВЕ зіасе ТТКЕ 'Нью-%'; 


НЕВЕ Ғігзі папе ІКЕ_'Ажо%'; 
1 джон [ Джошуа 


М/НЕКЕ мока ШКЕ '_н%; 


138 глава 2 


команда ЗЕ ЕС} 


Проверка диапазонов с использованием АМО 


и операторов сравнения 


Владелец бара хочет отобрать напитки, калорийность которых на- 
ходится в заданном диапазоне. Как составить запрос для получения 
названий напитков, у которых калорийность находится в диапазоне 


от 30 до 60 включительно? 


агіпк іпЁо 


33 


га 
да 
О 


зыя [д | 
ВЕТ а 
ОЕ РЕЯ 


Н 
до 
Е 
д | 


ЅЕІЕСТ агіпк пате ЕКОМ агіпк 1пЕо 


"НЕВЕ 
са1огіеѕ >= 30 
АМО 


са1огіеѕ <= 60; 


<— Резульилаил запро- 
са включает напиидки, 
9 коилорых калорийносил! 
больше или равна 50. 


уе" но меньше или равна во 


Ә5ги-ше * 
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ключевое слово ВЕТИЕЕМ 


Только МЕЖДУ нами... Есть и другой способ 


Также для проверки вхождения значений в диапазон можно 
воспользоваться ключевым словом ВЕТИЕЕКМ. Такая форма 
записи короче предыдущего запроса, но возвращает те же 
результаты. Обратите внимание: ВЕТМЕЕМ включает границы 
диапазона (30 и 60). Конструкция ВЕТИЕЕМ эквивалентна ис- 
пользованию операторов <= и >=, но не <и >. 


ЗЕБЕСТ агіпк пате ЕВОМ агіпк 1пЕо 
ИУНЕВЕ 
са1огіез ВЕТМЕЕМ 30 АМР 60; <_ Давил илочно илакой же резуле- 


илаил, как и запрос на иредыду- 
щей силраниие, но ВВодиился 
Включаем налиўлки те 


с 50 и ФО калориями: 


Ее Еа Ууіпдом Нер МейіштСаіогіеѕ 
> ЅЕ1ЕСТ Ягірк пате ЕВОМ дгіпк іпѓёо 
УНЕВЕ 


сафог1ез ВЕТМЕЕМ 30 АМО 60; 
+ 5 
| ахіпк пате | 
+ + 


Терновник 
Вот тебе на 
Борзая 
Бабье лето 
Сода плюс 


140 глава 2 


команда 5ЕТЕСТ 
«Возьми в руку карандаш 


Ч 
Измените запрос на предыдущей странице так, чтобы он воз- 


вращал названия всех напитков, содержащих более 60 или 
менее 30 калорий. 


Попробуйте использовать ВЕТИЕЕМ с текстовыми столбцами. Напишите запрос, который 
возвращает названия всех напитков, начинающиеся с букв от «Д» до «О». 


Как вы думаете, какой результат вернет следующий запрос? 


ЗЕБЕСТ аг1пК пате ЕКОМ агіпк 1пЕо "НЕВЕ 
са1огіеѕ ВЕТИЕЕМ 60 АМО 30; 


дальше » 141 


возьми в руку карандаш. решение 


«Возьми в руку карандаш 


. Решение Измените запрос на предыдущей странице так, чтобы он воз- 
=“ вращал названия всех напитков, содержащих более 60 или 
менее 30 калорий. 


СЕГЕСТ дім. маиле ЕКОМ дниК_тЮ 


Названия напиилков, содержащих 
е. У\НЕВЕ тс бодее 60. Калорий,........... а... 


саоне$ < 50 ОВ саіогіеѕ > ФО; 


аа Напиилки, содержащие 


менее 50 калорий. 


Попробуйте использовать ВЕТИЕЕМ с текстовыми столбцами. Напишите запрос, 
который возвращает названия всех напитков, начинающиеся с букв от «Д» до «О». 


СЕГЕСТ ЯАник_паитле ЕВОМ аниКк_тЮ 


„ково пово сова нь ва воъъ о вос вов оо вов о о ооо оо пов оо о зо ное зе о вое ооо новь ааа о ооо вече оо ча вон чо оно во оооь наф о ионов ао фе овоонь 


еннен ение еа ооа во нана в ево а ооо воно ино нони нов оное ня новее во нор ооо во янь а в но кофе зона таван оороо овет оноо 


Запрос возврамаеи^ названия 
всех налиилков, начинающихся 
с Д, О и всех букв между ними. 


Как вы думаете, какой результат вернет следующий запрос? 


ЗЕЕСТ дгіпк пате ЕВОМ дгіпк іпёо ИНЕВЕ 
са1ог1ез ВЕТИЕЕМ 60 АМЮ 30; 


Порядок указания границ важен, поэилому эилоил запрос 
не вернеил. ни одной записи. 


Запрос ищет значения, находящиеся в диапазоне от 60 до 30. Одна- 
ко в этом диапазоне значений нет, потому что 60 больше 30. Чтобы 
ключевое слово ВЕТИЕЕМ работало так, как положено, меньшее число 
всегда должно указываться первым. 
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команда 5Е1 ЕСТ 


Условие [№ 


Аманда, подруга Грега, использует список контактов Грега для 
поиска парней. Она уже побывала на нескольких свиданиях, за- Ь1аск БооКк 


вела собственную таблицу со своими впечатлениями. 
Тата тане [генез 


Аманда назвала свою таблицу р1аск Броок. Она хочет получить 


список удачных свиданий, поэтому отбирает значения к положи- 
тельным оценкам. 
ЅЕІЕСТ ааіе пате [Г 


РВОМ Б1аск Боок 


МНЕВЕ Положиилелонее 
а оценки ^>| Энтони восхититель- 

гаёіпд = ‘оригинально ‘< 5 но 

ов Фмдельңое лови 

гаё па = ‘потрясающе! „^ “2000 положи. Аа уе 

Ов и. 


- 
... ГА 


Вместо того чтобы строить длинные цепочки ОВ, мы можем 
упростить запрос при помощи ключевого слова ІМ. После ІМ 
следует набор значений в круглых скобках. Если значение столб- 
ца совпадает с одним из значений набора, то запись или задан- 
ное подмножество столбцов включаются в результат запроса. 


За ключевым словом 1М 
РЕР Иб е вана следцеил набор долцсили- 


ЕВОМ Ь1аск роок мех значений. Ее Бал Үлодоы Нер Соо СС 
27 ЅЕГЕСТ дае пате ЕВОМ Б1аск Боок 
ННЕВЕ (“= е 


гаЕ1па ІМ ('оригинально', аііпд ІМ ('оригинально', 'потрясающе', 
'потрясающе' 7 'восхитительно', 'неплохо'); 
'"восхитительно!'!, 
'неплохо'); 


Набор положительных 
оценок. 
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ключевые слова МОТ ІМ 


Ключевые слова МОТ [№ 


И конечно, Аманда хочет знать, кто из ее знакомых по- 
лучил плохие оценки. Если они позвонят, у нее обнару- 
жатся какие-нибудь неотложные дела. 


Чтобы получить имена знакомых, получивших низкие 


оценки, поставьте перед ТМ ключевое слово МОТ. С кон- Не входишь 


струкцией МОТ ТМ в выборку включаются записи, у ко- в набор? 
торых значение столбца не входит в заданный набор. Свободен! гі 
ЗЕ Ыр? 


ЅЕІЕСТ ае папе к 6 
— лючевые слов 
ЕВОМ Ь1аск Боок означаюил, ть 


ИНЕВЕ ҝ аа но одит 6 задан- 


Ней набор. 
габіпа МОТ ІМ 
('оригинально', 

" П 
потрясающе 
Бр А Вращаеил список зна - 
4 комых, не получивиих 


т пл т 3 
невношве?т, положиилельных оцё - 
нок, а следоваилелено, 


не имеющих шанса на 
Й вилорое свидание. 
Ейе Еан \Модом Нер ВадОаѓеѕ 


> ЗЕТЪЕСТ дае пате ЕВОМ Ь1аск Боок 
МНЕВЕ 


Запрос МОТ 1М воз- 


хаелпа МОТ ІМ ('оригинально', 
'потрясающе', ‘восхитительно', ‘неплохо'); 


0с МОЗГОВОЙ 
СООШТУРМ 


| аа+е пате 

е '— 
Джеймс 
Борис 
Мелвин 
Эрик 
Айвен 
Вик 

+ - + 


Когда мот тм удобнее ІМ? 


6 гомѕ іп ѕеї (2.43 зес) 


144 глава 2 


Другие применения МОТ 


Ключевое слово МОТ может использоваться не толь- 
ко с ІМ, но и с ВЕТИЕЕМ и 11КЕ. Однако необходимо 


помнить, что МОТ следует сразу же после ИНЕВЕ. 
Рассмотрим несколько примеров. 


команда ЗЕЕЕСТ 


ЗЕБЕСТ агіпк пате ЕВОМ агіпк 1пЕо 
МНЕВЕ МОТ сагЬз ВЕТИЕЕМ 3 АКО 5; 


Если ключевое 
слово МОТ исполе- 


ЅЕГЕСТ Ӣаёе пате ЁЕгом ЬІаск Боок 


зцеился с АМР или МНЕВЕ МОТ дае пате ІІКЕ 'А%' 


ОВ, ио оно 3а 
лисываеился после 


АМР” или ОК. ЕР: 


частро 
Задаваемые 


АМО МОТ дае пате ГТКЕ 'Б%'; 


Вопњсы 


| Вы же только что сказали, что МОТ записывается после 
УНЕБВЕ. А как насчет МОТ ІМ? 


|} Это исключение. И даже если поставить МОТ после ИНЕКЕ, 
команда все равно будет работать. Следующие две команды 
возвращают одинаковые результаты: 

ЗЕЪЕСТ * РВОМ еазу Чг1пК$ 

ИНЕВЕ МОТ па1п ІМ ('содовая', 'холодный чай'); 


ЅЕІЕСТ * ЕКОМ еазу Чг1пк$ 


ИНЕВЕ па1п МОТ ІМ ('содовая', 'холодный чай'); 


0 Будет ли МОТ работать с <> (оператор «не равно»)? 


() Будет, но это будет двойное отрицание. Намного логичнее 
заменить эту конструкцию знаком =. Следующие два запроса 
возвращают одинаковые результаты: 

ЗЕЪЕСТ * РВОМ еазу гілкѕ 

НЕВЕ МОТ агіпк пате <> 'Терновник'; 


ЗЕЪЕСТ * РВОМ еазу Чк1пК$ 
ИНЕВЕ Чг1пк пате = 'Терновник'; 


ђ: Как МОТ работает с МОТ1,? 


| |: Так, как и следовало ожидать. Например, чтобы выбрать все 
записи, у которых столбец не содержит МОТТ,, можно воспользо- 
ваться следующим запросом: 


ЗСЕЬЕСТ * РВОМ еазу_Чг1пК$ 
ИНЕВЕ МОТ таіп 1$ МОГ; 


Однако следующий запрос тоже подойдет: 


ЗЕЪЕСТ * РВОМ еаѕу дгіпкѕ 
ИНЕКЕ таіп 1$ М№ОТ МОБ; 


ђ: А как насчет АМР” и ОВ? 


() При использовании с АМР и ОВ ключевое слово МОТ ставит- 
ся после них: 

ЗЕЬЕСТ * РВОМ еаѕу Ягілкѕ 

ИНЕВЕ МОТ палп = 'содовая' 

АМР МОТ таіп = 'холодный чай'!; 
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операторы сравнения. упражнение 


Перепишите каждое из условий ИНЕВЕ так, чтобы они были как можно проще. Используйте 
АМР, ОВ, МОТ, ВЕТИЕЕМ, ІІКЕ, ІМ, 15 МОБ и операторы сравнения. Структура и содержи- 
мое таблиц приводились в этой главе. 


пражнение 


ЗЕЦЕСТ агіпк пате Егом еазу Ягіпкѕ 
ИНЕРЕ МОТ атопп®1 < 1.50; 


ЗЕЦЕСТ агіпк пате ЕВОМ агіпк 1пЕо 
МНЕВЕ МОТ ісе = 'Д'; 


ЅЕ1ЕСТ агіпк пате ЕЋОМ агіпк іпёо 


МНЕВЕ МОТ са1огіеѕ < 20; 
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упражнение. решение 


Перепишите каждое из условий ИНЕВЕ так, чтобы они были как можно проще. Используйте 
АМР, ОВ, МОТ, ВЕТИЕЕМ, 11КЕ, ІМ, 15 МОЪЬ и операторы сравнения. Структура и содержи- 
мое таблиц приводились в этой главе. 


пражнение 


ЗЕБЕСТ агіпк пате {гот еазу Аг1пК$ 
ИНЕВЕ МОТ атоцџпё1 < 1.50; 


ЅЕГЕСТ дүм мамле ЕКОМ еач_ЧилК$ 


ЗЕБЕСТ агіпк пате ЕВОМ агіпк іпёо 
МНЕВЕ МОТ ісе = 'Д'; 
те ЅЕГЕСТ Чик маиле РАКОМ дик 


ЗЕБЕСТ агіпк пате ЕВОМ бгіпк іпёо 
ИНЕРЕ МОТ са1огіеѕ < 20; 


ЅЕГЕСТ дүй мамле ЕВОМ Антик ибо 
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команда ЗЕЕЕСТ 


ЗЕБЕСТ агіпк пате ЕВОМ еазу_Чг1пКз 
ИМНЕКЕ таіп = 'персиковый нектар' 


ОК таіп = 'содовая'; те 
аил, поило 
ТА илаи немил других инт 
ЅЕГЕСТ агі парле ЕКОМ вазу АИК гредиенилов, идовлеилворяю дих е 
СТ акик мамле РКОМ еаѕу ЯК... А о таблиц 
с множесилвом залисеи илакое 
решение не подойдемм. 


ЅЕГЕСТ агіпк пате ЕВОМ агіпк іпёо 


УНЕВЕ МОТ са1огіеѕ = 0; 


ЅЕГЕСТ атик. памле РКОМ ЧК... Калорийносиль не быв 
г оилрицаилельной до" 
НЕВЕ ОН Оаа д использование ороо ОМУ 
безопасно. Рағорагъ 


ЅЕГЕСТ агіпк пате ЕВОМ агіпк іпёо 


МНЕВЕ МОТ сагьѕ ВЕТИЕЕМ 3 АМр 5; 
ЗЕГЕСТ діл ламле ЕВОМ диикиЮ 


М/НЕВЕ сагйб$ < 5 
еее наннан 


ЅЕГЕСТ дае пате Ёгот Ь1аск Боок 
МНЕКЕ МОТ Чафе пате ІКЕ 'А%' 


АМО МОТ ЧаЕе пате ТТКЕ 'Б%'; 
ЅЕІ ЕСТ дае мамле ЕКОМ (аск боок 
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краткий обзор =! 


Новые инструменты 


Мы подошли к концу главы 2, а ваш инструментарий 
пополнился несколькими новыми операторами 

и ключевыми словами. Полный список инструментов 
приведен в приложении ІІ. 


ГЛАВА 2 


ея, НИИ 
| = <> <> <= >= 


В вашем распоряжении 
полный надор операилоров 
сравнения. 


1$ МОТ, 


Условие для проверки значе- 
ния мот, 


п 


Новые инсилруменили, 
операторы! 
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команда 55! ССТ 


Бар Неаа Еігѕќ гоџпаде включает в свое меню фруктовые коктейли. Используя то, что вы 
пражнение Узнали в главе 1, создайте таблицу и вставьте в нее приведенные ниже данные. 


Со с. 93 Таблица входит в базу данных с именем ӣгіпкѕ. База данных содержит таблицу 
Ромение еазу_аг1пкз с рецептами напитков, состоящих всего из двух ингредиентов. 


"іе а Желаилельно выделииле несколе- 
Чир" ко лишних символов на олде? 
если илам когда-нибудь пояби 


СВЕАТЕ ТАВЬЕ еаѕу бгіпкз ся более длинное название 


(дгіпк паше УАВСНАВ (16), таіп УАВСНАВ (20), атоопё1 рЕС (3,1), 
зесопі УАВСНАВ (20), атоцпЕ2 ОЕС (4,2), дісесіјопѕз УАВСНАК (250)); 


ТЫЗЕВТ ТИТО еазу агіпкѕ Не за бу дьиле: ана ве не 


з" и 6 кавычки не Заклнчаюился! 
‘тоник', 1.5, 


('Терновник', "ананасовый сок', 1, 'взболтать со льдом, разлить 
по бокалам, украсить лимонной цедрой'), ('Голубая луна', ‘содовая', 1.5, 
'черничный сок', .75, ‘'взболтать со льдом, разлить по бокалам, украсить 
лимонной цедрой'), 
(‘Вот тебе на', 'персиковый нектар', 1, ‘ананасовый сок', 1, 'взболтать 
со льдом, разлить по стаканам'), 
('Лаймовый физз', 'Спрайт', 1.5, 'сок лайма', .75, 'взболтать со льдом, разлить 
по бокалам'), 
('Поцелуй', ! вишневый сок', 2, 'абрикосовый нектар', 7, 'подавать со льдом 
и соломинкой'), 
('Горячее золото', 'персиковый нектар', 3, 'апельсиновый сок', 6, 'влить 
в кружку горячий апельсиновый сок, добавить персиковый нектар’), 
('Одинокое дерево', 'содовая', 1.5, ‘вишневый сок', .75, 'взболтать со льдом, 
разлить по бокалам'), 
('Борзая', 'содовая', 1.5, 'грейпфрутовый сок', 5, ‘подавать со льдом, 
тщательно взболтать'), 
("Бабье лето', 'яблочный сок', 2, 'горячий чай', 6, 'налить сок в кружку, 
добавить горячий чай'), 

вы "холодный чай', 1.5, 'лимонад', 5, ‘подавать на льду с ломтиком 

` лайма!) 

('Сода 


', 2, 'виноградный сок', 1, 'вэболтать в бокале, подавать 


Надор данных ка 


ждого н Наииилки ра 
заключен в круг апиилка Разделяюился 


лЫе скобки. запяилыми. 
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3 РИТ. < ОАТ 
* 


+ О пользе изменений 
ж 


И в следующий раз не увлекайся 
с этой командой ОЕІЕТЕ, 
ладно? У меня на гостинцы 
никаких денег не хватит. 


Никак не можете прийти к окончательному решению? 
И ладно! Команды, с которыми вы познакомитесь в этой главе — 
рЕІЕТЕ и ОР”РАТЕ, — избавят вас от возни с данными, которые вы 
ввели полгода назад. Команда ОРРАТЕ изменяет данные, а команда 
РЕТЕТЕ удаляет данные из таблицы, которые вам больше не нуж- 
ны. Но мы не только рассмотрим новые инструменты, в этой главе 
вы узнаете, как избирательно применять новые возможности и как 
предотвратить случайное удаление полезных данных. 


информация о клоунах 


Клоуны Вокруг нас 


Предположим, мы хотим хранить информацию о клоунах, работаю- 
щих в городке Дейтавиль. Данные хранятся в таблице с1омп іпѓо, 
а текущее местонахождение клоунов содержится в столбце і азі ѕееп. 


НОЗРІТАІ. 


< ЕАК’ — 
м АШТОС “Ветом 


Ѕепюг Сетесг 
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деве и ирдае 


Информация о Клоунах 


Вот как выглядит наша таблица. Информацию, которой мы пока не располага- 
ем, можно пропустить — она будет введена позднее. Каждый раз, когда в городе 
появляется новый клоун, в таблицу добавляется новая запись. Чтобы содержи- 
мое таблицы оставалось актуальным, его придется часто изменять. 


Месило, 


эру а, 
хоё каЖоого клоуна 


бидели 6 последнии раз с1омп іпЁо 


[=== | Инне [| ние | зна | 
пел верна дна руна [М онхевав олын остеморомые вотни [мм | 


Скутер Больница Окленд М, синие волосы, красный костюм, большой нос шарики 
Торговый центр Милстоун Ж, оранжевый костюм, штаны 


Бэйб Автошкола р Ж, розовый костюм с блестками эквилибристика, 
машинки 


Заведение Трэй х9 М, зелено-фиолетовый костюм, длинный нос Е | 


| | иные яме 
( \ 14 амо^ 
| \ | бету @ ул 3 
Бе Сетет | 5404 улоз0 
см0! 


ОАКІАМО 
НОЗРІТАІ. 


Вертопе 
Зепог Сешег 


Е" 
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возьми в руку карандаш 


„Возьми в руку карандаш 
Перемещения КлоуноВ 


Напишите команды 50! для занесения текущей информации о клоунах 
в таблицу с1омп_1пЕ0. Учтите, что часть информации остается неиз- 
менной; за полными сведениями обращайтесь к таблице на с. 155. 


ъ. 


ІМЅЕВЕТ (МТО соми шо 


Зииио мелре 
лоёил. 


Снаглз носиил 
синие шианы. 


Бонзо Видели 
парке Диксон. 


Снифлз разъезжа- 
ем на машинке. 


Мисилера Хобо 
видели на вече- 
ринке Эрика Г рея 
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еее г: ирдае 


Как будет выглядеть таблица с1омп_1пЕо после выпол- 
нения команд ТМЗЕВТ? Допишите новые записи. 


НИНЕ МЫР 


Элси Дом престарелых Ж, рыжие волосы, зеленый костюм, шарики, машинки 
Черри Хилл огромные ботинки 


Снаглз Болмарт Ж, желтая рубашка, красные штаны рожок, зонтик 


Мистер Хобо Цирк ВС М, сигара, черные волосы, маленькая скрипка 
шляпа 
Кларабелл Дом престарелых Ж, розовые волосы, большой цветок, кричалки, танцы 
Бельмонт синее платье 
Скутер Больница Окленд М, синие волосы, красный костюм, шарики 
большой нос 
Зиппо Торговый центр Ж, оранжевый костюм, штаны танцы 
Милстоун 
Автошкола Эрла Ж, розовый костюм с блестками эквилибристика, 
машинки 


Снифлз Заведение Трэйси М, зелено-фиолетовый костюм, длин- 
НЫЙ НОС 
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возьми в руку карандаш. решение 
Возьми в руку карандаш 


`` шение Перемещения Клоунов 


Напишите команды 50! для занесения текущей информации 
о клоунах в таблицу с1омп іп Ғо. Допишите в таблицу записи, 
которые появятся в ней после выполнения команд ТМЗЕВТ. 


ІМЅЕВТ (МТО с(оми_мЮ 


ИО а ов нн ко вре воа в вап о зако аь ин ори уно имо ъа ни урал нве сонное 


Зиипо илепере МАЕИЕ$ 


Снаглз носиил 
синие шиланы. 


Бонзо видели 
парке Диксон. 


Снифлз разъезжа- МАЕОЕ$ 
ре а О ороор 


МИИНЭН ово сана воно о ево ва ва ово ава ооо вовья 


‘разъезжает на машинке"); 


ІМЅЕРТ (МТО соми диЮ 


УАНОЕЗ 


Мистера Хобо 
видели на вече- 
ринке Эрика Грея. 
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деее и ирааќе 


пате | ми | чение | чине | 
Дом престарелых Ж, рыжие волосы, зеленый костюм, шарики, машинки 
Черри Хилл огромные ботинки 
Вечеринка Джека Грина М, оранжевые волосы, синий костюм, 
огромные ботинки 


Снаглз Болмарт Ж, желтая рубашка, красные штаны рожок, зонтик 


Мистер Хобо Цирк ВС М, сигара, черные волосы, маленькая скрипка 
шляпа 
Кларабелл Дом престарелых Ж, розовые волосы, большой цветок кричалки, танцы 
Бельмонт синее платье 
Скутер Больница Окленд М, синие волосы, красный костюм, шарики 
большой нос 
Зиппо Торговый центр Ж, оранжевый костюм, штаны танцы 
Милстоун 4 
Бэйб Автошкола Эрла Ж, розовый костюм с блестками эквилибристика, 
машинки 


М, женское платье в горошек пение, танцы 


Заведение Трэйси М, зелено-фиолетовый костюм, длин- 


НЫЙ НОС 


Торговый ценмр |Ж, оранжевый косилюм, иланиы, пение 


Милсилоун ииланы 


Ж, желилая рубашка, крас- | рожок, зонилик 
ные миланы 

М, женское плаилье 6 горо- |иение, иланиы 
шек 


М, зелено -фиолеиловый разъезжаеил на 
косилюм, длинный нос машинке 


М, сигара, черные Волосы, скрипка 
маленькая шляпа 


Как узнать текущее местонахождение конкретного клоуна? 
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можно ли получать данные в хронологическом порядке? 


Как ВВодятея сведения о Клоунах 


В службе сбора информации о клоунах работают волонтеры. 
Иногда отчеты лежат неделю-другую в ожидании ввода дан- 
ных. А иногда двое сотрудников делят стопку отчетов между 
собой и вводят данные одновременно. 


Учитывая этот факт, рассмотрим содержимое таблицы для 
клоуна Зиппо. Для выборки данных можно воспользоваться 
командой ЗЕТЕСТ: 


Ейе Еай \УМпдом Нар СаісҺТҺеСіомтп 
ЗЕЬЕСТ * ЕВОМ с1очп_1пЕо ИНЕВЕ пате = 'Зиппо'; 


\\ 
5 Абсолюилно одина - Эили записи може 
ковые записи. полносилею совла- 


даюим. 


Можно ли обратиться к данным с запросом и получить 
только последние сведения о Зиппо? Можно ли опреде- 
лить, где этот клоун выступал в последний раз? 
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Г ар Г чик | же 


\ Информация повилоря- 


вился снова и снова. 


очень просто. Достаточно 
обратиться к последней записи. 


деее и ирдае 


Конечно, это 


К сожалению, ничто не гарантирует, что 
последняя запись окажется самой новой. 


Вспомните, что вводом данных одновременно зани- 
мается сразу несколько человек, а отчеты могут быть 
переложены в другом порядке. Но даже если этого 
не произошло, не рассчитывайте на то, что записи 
таблицы следуют в хронологическом порядке. 


Существует целый ряд внутренних факторов, кото- 
рые могут повлиять на порядок хранения записей 

в таблице, в том числе используемая РСУБД и индек- 
сы столбцов (об этом позднее). 


Ничто не гарантирует, что последняя 
запись таблицы была добавлена 
позднее других запиеей. 


дальше » 
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о структуре таблицы 


Бонзо, у нас проблема 


Так как мы не можем быть уверены в том, что последняя запись была добавлена позже 
остальных, возникает серьезная проблема. Из таблицы можно получить информацию 

о том, где находились клоуны в тот или иной момент времени. Но сама таблица создава- 
лась для получения информации о том, где каждого клоуна видели в последний раз! 


И это не все. Обратили внимание на одинаковые записи? Две записи содержат информа- 
цию о том, что Зиппо видели в одном и том же месте, за одним и тем же занятием. Дубли- 
каты занимают место и замедляют работу РСУБД с увеличением объема таблиц. В табли- 
це не должно быть дубликатов. В одной из следующих глав мы поговорим о том, почему 
дубликаты нежелательны и как предотвратить их появление. Вы узнаете, как создать 
таблицы, в которых дубликаты в принципе невозможны. А пока исправим существующую 
таблицу так, чтобы она содержала полезные данные. 


Часто 
Задаваемые 


Вопісы 


* 
• Почему нельзя считать, что последняя запись была 
добавлена позже остальных записей? 


() Порядок следования записей в таблице не гарантирован; 
к тому же скоро вы узнаете, как изменить порядок записей 

в полученных результатах. Нет полной уверенности в том, 
что последняя запись действительно была вставлена 
последней. Кроме того, порядок следования записей может 
быть нарушен из-за «человеческого фактора». Предполо- 
жим, мы вводим две команды ІМЅЕКТ для одного клоуна. 
Если не хранить в таблице информацию о том, в каком 
порядке делались эти наблюдения, мы не будем знать, какое 
из них произошло первым. 


0: Допустим, мы помним порядок наблюдений. Так по- 
чему не использовать последнюю запись? 


() Немного расширим пример. Информация о клоунах 
собиралась годами. В штате есть несколько помощников, 
которые тоже ведут наблюдения и добавляют свои записи. 
Для некоторых клоунов созданы сотни записей. При выборке 
мы получим эти сотни записей и нам придется перебирать 
их до последней — которая, как мы надеемся, была введена 
позже других. 
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О 
• А стоит ли хранить такие данные в таблице? Есть ли 
смысл во вставке новых записей с сохранением старых? 


(} Безусловно. Возьмем текущий пример: таблица в своем 
текущем виде хранит не только последнее местонахождение 
каждого клоуна, но и историю его перемещений. Вполне воз- 
можно, что эта информация окажется полезной. Проблема 

в том, что запись не содержит информации о том, когда про- 
изошло данное событие. Если добавить в таблицу столбец 

с датой и временем, мы получим возможность отслеживать 

перемещения клоунов с гораздо большей точностью. 


Но сначала необходимо как-то избавиться от дубликатов, 
чтобы упростить содержимое таблицы. 


К концу книги я буду знать, как спроектировать 
таблицу без дубликатов. А если плохо спроектированная 
таблица досталась мне от человека, который раньше 
работал на моем месте? 


а 


О 

(; Плохо спроектированные таблицы встречаются сплошь 
и рядом. Большинству людей, изучающих 501, приходится 
исправлять чужие ошибки. 


Существует несколько методов борьбы с дубликатами. 

На данный момент мы еще не располагаем инструментами, 
необходимыми для исправления плохих данных, но непре- 
менно вернемся к ним позднее. 


аеіеќе и ирдаќе 


Уничтожение записей Командой ОЕТЕТЕ 


Похоже, нам придется почистить таблицу и избавиться от некоторых 
записей. Чтобы с таблицей было удобнее работать, для каждого клоуна 

в ней останется только одна запись. При появлении очередной информа- 
ции о Зиппо (которая заведомо новее предыдущих) из таблицы удаляют- 
ся старые данные Зиппо, ставшие неактуальными. 


Удаление записей из таблиц осуществляется командой ОРЕЪЕТЕ. В этой 
команде используются уже знакомые нам условия МНЕБЕ. Попробуйте по- 
нять, как выглядит синтаксис команды, прежде чем мы покажем его. 


Снова приведем записи Зиппо. 


Болмарт Ж, оранжевый костюм, штаны танцы, жонглирование 
Зиппо Торговый центр Милстоун Ж, оранжевый костюм, штаны танцы, пение 
Больница Окленд Ж, оранжевый костюм, штаны танцы, пение 


Магниты с Кодами 


Мы написали простую команду для уничтожения одной из 
записей о клоуне Зиппо, но магниты с фрагментами команды 
полностью перепутались. Соберите фрагменты и укажите, что, 
по вашему мнению, делает каждая часть новой команды. 


Алосилрофы, заляилые. 
знаки рабенсилва и сим- | =вом | кН 
болы <<:» слишком малы, 


Чилоды доддирдиль их, Д 


Рассилавьиле их мо своеми = | 
/ 


9сМоидреникюо. 
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магниты с командой РЕ ЕТЕ ответ» 


еу. 


ик аГниуры с Кодами 
ә \ 


Мы написали простую команду для уничтожения одной из записей 
| о клоуне Зиппо, но магниты с фрагментами команды полностью пе- 
репутались. Соберите фрагменты и укажите, что, по вашему мнению, 
делает каждая часть новой команды. 


В оилличие оил 


команды ЗЕТЕСТ 
ваиль, чило именно и 96 


9даляеился, не е 
команда цдаляеил 6 Мено 


Сн запись. 
| Е ТЕТЕ Г РЕШЕ", 


Таблица, из комлороч 


ч идаляеился запись. 
== 43 Добавьиле олераи^оР 


«равно», алосилрофы по А 
обе силороны оил Магний 


Рт <«<илание> и символ <<. 
26340 
д я = Д 


А Е У/НЕКЕ 


(см. иредыд 
И не забудыме доба- главу) определяеил, какая и 
вииль условие НЕВЕ, Запись удаляется командой Ре! т 
а ило команда чдалии^ | 


Все залиси! 


Эили магниилы в команде 
не используюился. 


м. 
Условие \УНЕВЕ в командах –ЕІЕТЕ < = 
работает точно так же, 


как в командах ЗЕГЕСТ. 
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ЦепользоВание Команды ОЕТЕТЕ 


Взгляните на построенную нами команду РЕТЕТЕ. Она работает 
именно так, как и следовало ожидать: все записи, соответствую- 
щие условию ИНЕКЕ, удаляются из таблицы. 


РЕГЕТЕ ЕВОМ с1омп_1пЕо 
ИНЕВЕ 
асііуіііеѕ = !'танцы!; 


Скутер Больница Окленд М, синие волосы, красный костюм, большой нос 
евыи к 


Зипп‹ Торговый центр Милстоун Ж, оранжевь 


/ стюм, штаны 
Ж, розовый костю 


Снифлз Заведение Трэйси М, зелено-фиолетовый костюм, длинный нос 
Зиппо Торговый центр Милстоун Ж, оранжевый костюм, штаны 


Снифлз Заведение Трэйси М, зелено-фиолетовый костюм, длинный нос 


Мистер Хобо Вечеринка Эрика Грея М, сигара, черные волосы, маленькая шляпа скрипка 


со мозговой 
оозго 


Как вы думаете, может ли команда РЕЪЕТЕ 


удалить только один столбец из записи? 


деіеќе и ирааќе 


[_ вне ИЕ ТИ 
Элси Дом престарелых Ж, рыжие волосы, зеленый костюм, огромные шарики, 
Черри Хилл ботинки машинки 
Вечеринка Джека Грина М, оранжевые волосы, синий костюм, 
огромные ботинки 


Болмарт Ж, желтая рубашка, красные штаны рожок, зонтик 
Мистер Хобо Цирк ВС М, сигара, черные волосы, маленькая шляпа скрипка 


Кларабелл Дом престарелых Ж, розовые волосы, большой цветок, кричалки, 
Бельмонт синее платье танцы 


шарики 


танць 


м с блестками эквилибристика, 
машинки 


о Ни. ви женское плате в тароша НЕ 


Снаглз Болмарт Ж, желтая рубашка, красные штаны рожок, зонтик 
Бонзо Парк Диксон М, женское платье в горошек пение, танцы 


разъезжает 
на машинке 


дальше » 


Запись, коилорая 
будеил удалена. 


го 
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Правила ОЕТЕТЕ 


„ Команда РЕТЕТЕ не позволяет удалить значение одного столбца 
или группы столбцов. 


„ Команда ОЕЪЕТЕ удаляет из таблицы одну или несколько запи- 
сей (в зависимости от условия ИНЕВЕ). 


"„ Мы рассмотрели пример удаления одной записи из таблицы. 
Также возможно удаление сразу нескольких записей. Для этого 
критерий выбора удаляемых записей определяется при помощи 
условия ИНЕВЕ. Синтаксис условия МНЕВЕ полностью совпада- 
ет с синтаксисом НЕБЕ в команде 5ЕТЕСТ (см. главу 2); в нем 
могут использоваться все конструкции из главы 2, в том числе 
ТІКЕ, ІМ, ВЕТИЕЕМ и операторы сравнения. 


„ Будьте осторожны — следующая команда удаляет из таблицы 
все записи: 
РЕТЕТЕ ЕВОМ уоиг бар1е 


м частро 
ЗадаВаеМые 
т Вопсы 


Условие НЕВЕ в команде РЕЦЕТЕ чем-нибудь 
отличается от ИНЕВЕ в команде ЗЕЦЕСТ? 


( Ничем. Условия ИНЕВЕ одинаковые, но сами 
команды ЅЕТЕСТ и ”РЕТЕТЕ существенно отличаются. 


Команда ЗЕТЕСТ возвращает копию столбцов из записей, 
удовлетворяющих условию ИНЕБЕ, не изменяя таблицу. 
Команда РЕІРТЕ удаляет все записи, удовлетворяющие 
условию ИНЕВЕ. 
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ае!ее и ирдайе 


(звань ШГ с УсЛоВиеМ МС 


- [релепавыре себя на Местре груплы ҡоманд 


ПІП с УсЛеВинМи М. ()љрелелите, 


Удалято Ли этри КоМанды Какие—Либо 


записи из трабЛиЦы, 


роведитое Линию отп Каж- 


РЕГЕТЕ ҒКОМ аоцџдһпоб га%ф1п9д$ доГо условия К улаляемей 


записи (ила залисям) . 


ИНЕВЕ 1осабіоп 'Кг1зру Капа' АМО гаїіпд <> 6; 


ИНЕВЕ Іосабіоп = 'Кг1зру К1пд' АМ) габіпд = 3; 
МНЕВЕ Іосаёіоп = 'Ѕпарру Ваде1' АМ0 гаііпд >= 6; 
ИНЕКЕ 1осаёіоп = 'Кгіѕру Кіпд' ОВ гаїіпд > 5; 
МНЕВЕ 1осаііјоп = 'Кг1зру Кіпд' ОВ гаїіпд = 3; 


ИНЕВЕ 1осабіоп 'бпарру Ваде1' ОВ гаїіпд = 6; 


аоцадћпиё габіпдѕ 


анаа Гаю | че [ен рааны 
[бокал боли | 859 [25/8 [ми [6 | жирноваы | 
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стань ОЕ ЕТЕ. ответ 


(тоань ИГТ с УсЛоВиеМ МИЛЕ. (авео 


4 [редатавьтре себя на Месте Группы КоМанд 


ТРПИ: зеленим ПИСК. Озғелелае 


Удалятр Ли этри Команды какче—Либо записи 


из трабЛиЦы, 


[Проведите Линию отр Каж- 
ДоГо ЦсЛоВия к ЧдаЛяеМой 
записи (шли записям): 


РЕГЕТЕ ЕВОМ аоцдһпиб га+іпаѕ 


МНЕВЕ Іосабіоп = 'Кгізру Кіпд' АМО гаёіпд <> 6; — 


Неил совпадений, 
записи не чдаля- 
нимся. 


МНЕВЕ Іосабіоп = 'Кгізру Кіпд' АМО габіпд = 3; 


Неил совпадений, 
записи не удаля- 
нился. 


МНЕВЕ Іосаёіоп = 'Ѕпарру Ваде1' АМ0 гаїіпд >= 6; 


МНЕВЕ Іосаёіоп = 'Кгізру Кіпд' ОВ га+їіпд > 5; 


МНЕВЕ 1осаёіјоп = 'Кгізру Кіпд' ОВ гаїіпд = 3; 


Неил совладений, 
'5парру Ваде1' ОВ гаёіпд = 6; заииси не уда- 
боцдћпо+ гаёіпдѕ 


дяюидся. 
И нае | аа 


ИНЕКЕ 1осаііоп 


Г-енае |  сошенн 7, 
авахад О Са 7 поиде 
итии т а И 0 


Значения МИН. могуил создаиль и 

роблемы ири буд 
ввесили какое-нибудь значение, чем осилавляиль О 
му Чило МИН. не находиился по условию «равно». 


их запросах. Лучше 
Е 6 силолдие, поило- 
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деіеќе и ираае 


Танцы |М$ЗЕВТ-ОЕТЕТЕ 


В таблице содержится всего одна запись с данными 
клоуна Кларабелл. Так как мы хотим, чтобы в таблице 
оставалась всего одна запись с самой новой информа- 


ы Д и эила оилли- 
циеи, нужно создать новую запись и удалить старую. Оил другой запис 


чаеился илолько заняилием. 


СЯ ет б доме Наша задача 
аниче о — сохранить эилу 
К.ларабелл еа РЦ ; информацию 6 иладлице. Для эко- 


пресиларелих ре 
ж, розовые волос 
ивеилок, синее ил 


номии Месила 6 илаблице на с. 165 
приведена всего одна запись. 


с 
ало в. СО ПИ И 


Кларабелл Дом престарелых Ж, розовые волосы, большой кричалки, танцы 
Бельмонт 


цветок, синее платье 
є Сначала команда ІМЅЕКТ добавляет новую информацию (и старую тоже). 


сход - 
1 При всилавке используются и 
тан аи ООЗЕ РЕР А данные, а изменяёился илолЬко 


УАГОЕ5 обновленный силолдеи. 
('Кларабелл', 'Дом престарелых Бельмонт','Ж, розовые 


волосы, большой цветок, синее платье', ‘'танцы'); 


ы, большой 
аилье 


вате | шик | брани |  чмни | 
Кларабелл Дом престарелых Ж, розовые волосы, большой цве- кричалки, танцы 


Кларабелл Дом престарелых Ж, розовые волосы, большой цве- танцы 
Бельмонт ток, синее платье ; 
е Затем старая запись удаляется командой РЕТЕТЕ с условием МИНЕКЕ. 


РЕБЕТЕ ЕВОМ с1оип іпёо КЕЕ Для поиска и удаления 
ИНЕКЕ силарой записи исиоль- 
асііуіііеѕ = 'кричалки, танцы! 767 условие НЕБЕ. 
АМО пате = 'Кларабелл'; 


ІМЅЕРТ 


Ив таблице остается только одна — новая — запись. 


Кларабелл Дом престарелых | Ж, розовые волосы, большой цве- танцы 
Бельмонт ток, синее платье 
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возьми в руку карандаш 


_ Возьми в руку карандаш 
> Используйте команды ІМЅЕРТ и РЕЪЕТЕ и внесите в таблицу 


Ы Ҹ агіпк іпѓёо необходимые изменения. Затем запишите 
измененные данные в пустой таблице справа. 


агіпк іпЁёо 


синии 


оранжевый 
зеленый 


| 


Уменьшите калорийность «Поцелуя» до 170. 


Замените желтый цвет «золотистым». 


170 глава 3 


аеіеќе и ирдае 


дик іл Ёо 


ісе___| саїогіеѕ 


Горячее золоило 
Одинокое дерево 


Очередное каверзное упражнение? 
є) 


Для всех напитков, стоящих $2.50, поднять цену 
до $3.50, а для напитков с ценой $3.50 — до $4.50. 
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возьми в руку карандаш. решение 


„ Возьми в руку карандаш 


Решение Используйте команды ІМЅЕРТ и РЕТЕТЕ и внесите в таблицу 
гіпк іпЁо необходимые изменения. Затем запишите 
измененные данные в пустой таблице справа. 


агіпк іпѓёо 


ГЕТЕ ОНИ 
[35 [ 86 [ оранка | 


Уменьшите калорийность «Поцелуя» до 170. 


ІМЅЕВТ ІМТО аник_иЮ МАЈЕ ('Поцелиуй’, 5.5, 42.5, 


Замените желтый цвет «золотистым». 


ІМЅЕВТ ІМТО дкі ітЁо 


172 глава 3 


деіеќе и ирааќе 


дик 


[Терновник |5 аф [золотистый | 
Голубая луна |55 |52 [оний | 
Зою илебе на |45 — [8.6 
[Лаймовый физз {55 |54 [зеленый 

2 

14 

2 

4.7 


саіокіеѕ 


се 


а . 
76) й 
д Д 5.5 и 
НИК НЕЕ БН атака 8 


|47 [красный ___| 


СЖ Не илакое уж каверзное, но ио- 
Умаиль придеился. Е 


ОЕ 


иль илаблииа после 


де 
Так должна выгляде А базе данных под сли сначала 
внесения изменении. В Ат дрчгим, д КЕ, чену напиилков с $2.50 
порядок залисей можем дыиль РУ 4 25.50, а полом с $5 50 до 
.5 
но эило совериленно неважно ©, мо «Голубая луна» подо- 
НЙ рожаеил дважды. Вмесило_эилого 
НУЖНО сначала изменииль доль_ 
Очередное каверзное упражнение? ЧЮ цену (с $5.50 д 
р рэное упр о $4.50), 


а помом меньшцко («Голубая 
Ана» — с 42.50 до $5.50). 


Для всех напитков, стоящих $2.50, поднять цену до 
$3.50, а для напитков с ценой $3.50 — до $4.50. и 


ІМЅЕВТ (МТО ЯииКи МАГОЕЅ ('Воил илебе на', 4.5, 8.6, 


РЕГЕТЕ ЕКОМ дилк_иЮ \/НЕРЕ со5ё = 2.5; 


Дополнительные баллы, если вы объединили две команды ІМЅЕРТ в одну! 
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осторожно с удалением 


Будьте Внимательны при Выполнении ОЕТЕТЕ 


При выполнении команды РЕТЕТЕ всегда существу- 
ет опасность случайного удаления записей, которые 


Будьте внимательны при ис- 


ы удалять обирались. Допустим, в таблицу была 
Кое | рза к о Мистере обо: пользовании рЕГЕТЕ. 
бавляемая Убедитесь в том, чт 

т ие Е Ходо и О ОВИЕ 
и команда идели 6 заве- | \УНЕВЕ точно описывает уда- 

‚ 1МЅЕКТ для дении Трэйси. | 

\ ее добавления. ляемые записи и не включает 
ІМЅЕРТ ТМТО с1омп 1120 ничего лишнего. 


УАТОЕ$ 
('Мистер Хобо', 'Заведение Трэйси', 'М, сигара, 
черные волосы, маленькая шляпа', 'скрипка'); 


Элси Дом престарелых Ж, рыжие волосы, зеленый костюм, шарики, 
Черри Хилл огромные ботинки машинки 
Пиклз Вечеринка Джека Грина М, оранжевые волосы, синий костюм, мим 
огромные ботинки 
Снаглз Болмарт Ж, желтая рубашка, красные штаны рожок, зонтик 
Мистер Хобо Цирк ВС М, сигара, черные волосы, маленькая шляпа скрипка 


Кларабелл | Дом престарелых Бельмонт | Ж, розовые волосы, большой цветок, синее платье | кричалки, танцы 
Скутер Больница Окленд М, синие волосы, красный костюм, большой нос шарики 


Зиппо Торговый центр Милстоун Ж, оранжевый костюм, штаны танцы, пение 


Автошкола Эрла Ж, розовый костюм с блестками эквилибристика, 
машинки 


, 
Й 


Снифлз Заведение Трэйси М, зелено-фиолетовый костюм, длинный нос разъезжает 
ОЕІЕТ на машинке 


Мистер Хобо Парк Диксон М, сигара, черные волосы, маленькая шляпа скрипка 
Уистер Хобо | Заведение Трэйси М, сигара, черные волосы, маленькая шляпа скрипка 


А теперь станьте командой РЕГЕТЕ. 
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дее и ирдайе 


(ъъаньте КоМандой ТИ 


ДШ Ше приведены УсЛоВия МІГ Ала серии кеМанд ВІ, 


{ Кетпорые должны УдаЛить Лишние записи из тоабЛиЦы 


ет бо (Ае на предыдущей странице, (5ре- 
, 


деЛитре, какие УсЛоВин дейстрВитпеЛьно пюЛезны, 
а 


а какие Лишь создаютр НоВые проблемы. 


су 
| Команда полезна [ела нетр — Укажите, почему. 
ЮЕТЕТЕ РВОМ с1омп 1пѓо 


МНЕВЕ 1азЕ зееп = 'Больница Окленд'; 
МНЕВЕ асііуіїіеѕ = 'скрипка'; 

МНЕВЕ 1аѕе зееп = 'Парк Диксон‘ 

АМО пате = 'Мистер Хобо'; 


МНЕВЕ 1аз зееп = 'Больница Окленд! АМО 


1азЕ зееп = 'Парк Диксон’; 
МНЕВЕ 1азЕ зееп = 'Больница Окленд' ОВ 
1азЕ зееп = 'Парк Диксон’; 


МНЕВЕ пате = 'Мистер Хобо' 
ОВ 1азЕ зееп = 'Больница Окленд'; 


А тпеперъ напиШитре одну команду ИГТ, 


Котрорая удалит Лишние записи Мистера ү, 


не затрраГиВая друГих записей. 
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станьте командой ОЕГЕТЕ. ответ 


РЕГЕТЕ ЕВОМ с1омп іпёо 


Запись Скуилера иложе удовлетл- 
© воряеил эилому условию. 
МНЕВЕ 1азі зееп = 'Больница Окленд’; 


Новая запись не должна 
удаляилься. 
ИМНЕВЕ асёіуіёіез = 'скрипка'; 


МНЕВЕ 1аз®_ зееп = 'Парк Диксон' 
АМО паше = 'Мг. Норо'; 
Связка АМ” означаеил, чило оба чсло - 
вия должны быиль исилинными. 
‚ НЕВЕ 1азЕ_зееп = 'Больница Окленд' 
— АМР 1аз зееп = 'Парк Диксон'; 


ИНЕВЕ 1азі зееп = 'Больница Окленд' 
ОВ 1азі зееп = 'Парк Диксон'; 


МНЕВЕ папе = 'Мистер Хобо' 
ОВ 1азЕ зееп = 'Больница Окленд'; 


А тпеперь налититле одну команду 1, 


Котроран удаЛита ЛаШшние записи Мистрера ү, 


не затрраГиВая других записей, 
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Ы (мые командой ТТ. Озен 


[е приведены УсЛоВия МПТ для серич Команд ПИТ, Которые 


должны УдаЛитрь Лишние записи из трабЛицы Дом яо БЫ на 
предылущей странице. (зрелелитие, какие УсЛоВия дейстрВч – 
треЛьно поЛезны, а какие Лишь создают НоВые проблемы, 


К-манда зелева? [оч не —— укажчтре, почему. 


Удаляеил илолько одну запись Мистера 


весь о на оао еее но Ин а аваров оао евао но НОЕ 


ВЕЛАТ КЕННЕН КАКЕНОВ 


Мисилера Хобо. 


....Ничего. не. Чдаляеицм............. а нилньиинииньнииь 


Вмесиле со старыми записями Мисилера 


Скуилера. 


РЕГЕТЕ ЕКОМ соми їмо 


Похоже, вы удалили что-то 
лишнее? Возможно, стоило сначала 
выполнить команду ЅЕГЕСТ и по- 

смотреть, какие записи будут удалены 
с конкретным условием М/НЕРЕ. 


Точно! Если у вас нет полной 


ЅЕТЕСТ. 


с этим же условием ИНЕКЕ. 


все нежелательные записи. 


уверенности относительно того, что 
условие ИНЕВЕ удалит только нужные 
записи, сначала выполните команду 


Так как обе команды используют одинаковые 
условия ИНЕКБЕ, то команда ЅЕТЕСТ вернет 
записи, которые будут удалены командой РЕТЕТЕ 


Этот нехитрый прием предотвратит случайное 
удаление посторонних записей, а также поможет 
убедиться в том, что из таблицы будут удалены 


аеіеќе ‹ ирда{е 
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горести неточного удаления 


Проблемы е неточными условиями ОЕТЕТЕ 


Правильно написать команду РЕТЕТЕ сложно. 


Стоит допустить малейшую неточность, и команда Чтобы не удалить посторонние 


удалит посторонние данные. Для предотвращения 


удаления лишних данных в схему ІМЅЕКТ-РЕТЕТЕ записи, сначала выполните 


включается дополнительный шаг. 
команду ЗЕГЕСТ. 
Вот как выглядит новый план ИЗ ТРЕХ ШАГОВ: ома ВЕСТ. 


1) Сначала произведите выборку удаляемой записи комапдой ЗЕЪЕСТ. Убе- 
дитесь, что удаляются только те записи, которые вы собирались удалить — 
и никаких посторонних записей. 


ЅЕІЕСТ ЕРКОМ с1омп іпѓЁо 
ИНЕВЕ 
см асіітуіііеѕ = 'танцы'; 


пате | ми | проеме | сене | 
99 Зипо | Торговый центр Милстоун | Ж, оранжевый костюм, штаны 


Теперь добавьте новую запись командой ІМЅЕВТ. 
Б Ян ‚ Я изменииле иоле = 


2 ко илоил силолдеи, 


ТМЗЕВТ ІМТО с1омп іпёо ” коилорый нужно 
УАТОЕЗ и изменим. 
('Зиппо', 'Торговый центр Милстоун', 
"Ж, оранжевый костюм, штаны', 'танцы, пение'); 


гд, 

Ау 

Я | пате | № | _ арреағапсе | НУ» | 

с ы. 
=— 


пава 3 


деве и ирдае 


Наконец, удалите старые записи командой РЕІЕТЕ с тем же 
условием ИНЕКЕ, которое использовалось в команде 5ЕЪЕСТ 


на первом шаге. 


Используйте условие 


РЕГЕТЕ ЕВОМ с1омп_1пЕо ММНЕВЕ из команды 

НЕВЕ М РЕНА (шаг 1) для 
и иск 

асііуіііеѕ = 'тавцы; а 


пате |] __ Лез! вееп | арреағапеә | мене 
Зиппо Торговый центр Милстоун | Ж, оранжевый костюм, штаны танцы, пение 


В таблице остается только новая запись. 


Зиппо Торговый центр Милстоун | Ж, оранжевый костюм, штаны танцы, пение 


А как было бы здорово, 
если бы все можно было сделать 
за один шаг, не беспокоясь о том, ЧТО 
новая запись будет удалена вместе 
со старой... Но я знаю, что это всего 
лишь мечты... 


Зи. ^^ Зее 3 


и центр Милстоун 


Торговый 
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ОЈРРАТЕ в деиствии 


Изменение данных Командой ЏРОАТЕ 


Итак, вы достаточно хорошо разобрались в командах ІМЅЕКТ и ГЕІЕТЕ, чтобы обеспе- 
чить актуальность данных в своих таблицах. Также мы рассмотрели возможность со- 
вместного использования этих команд для косвенной модификации отдельных записей. 


Но вместо того чтобы вставлять в таблицу новую запись и удалять старую, можно об- 
новить существуюшую запись, изменив в ней значения только тех столбцов, которые 
требуется изменить. 


Для этой цели используется команда $01. ОРРАТЕ. Она обновляет столбец (или столб- 
цы) новыми значениями. Как и в случае с командами ЗЕТЕСТ и РЕТЕТЕ, для выбора 
обновляемой записи (или записей) можно задать условие ИНЕВЕ. 


Пример использования команды ОРРАТЕ: 


ОРРАТЕ аопарпаЕ габіпдѕ Знакомое УСА0 


Вие, \УНЕЁЕ, 
Здесь задаеил мк Аф и в коман 
новое А Суре = 'глазированные' дах ЅЕЕЕСТ 


и РЕГЕТЕ. 
МНЕВЕ ёүре = 'с глазурью’; о 


Ключевое слово 5ЕТ сообщает РСУБД о том, что в столбце, имя которого указано 
перед знаком =, должно быть сохранено значение, указанное после знака =. В при- 
веденном примере в столбец “уре записывается текст ' глазированные '. Условие 
ИНЕВЕ указывает, что изменения вносятся только в строках, у которых столбец ёуре 
содержит значение 'с глазурью’. 


ЗӢочдћпиё гаёіпдзѕ 
нше | ае 


почти идеально 


Кгіѕру Ктд 
Ѕагри22 Со# ее 19:35 24/5 


мало варенья 


енна | 
ГГТ [859 [58 | мы | СИ ЕНИ 


Аопарпае гаёіпдѕ 
| рокат оиз [859 | оза | мы [6 |  жрювы | 


Ѕїагриг22 Со ее 19:35 24/5 кекс скорицей 
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Правила УРОАТЕ 


ее и ирдае 


„ Команда ОРРАТЕ может использоваться для изменения 
значения одного столбца или группы столбцов. Включи- 


те дополнительные пары столбец = 


значение В усло- 


вие 5ЕТ и поставьте запятую после каждой пары: 


ОРРАТЕ уойг фаЮ1е 


ЗЕТ первый столбец= 'новое значение', 


второй столбец = 


'старое значение'; 


„ Команда ОРРАТЕ может изменять одну запись или 
несколько записей в зависимости от условия ИНЕВЕ. 


Частро 


Задаваемые 


Вось 


0: Что произойдет, если условие ИНЕВЕ не задано? 
(} Каждый столбец, указанный в условии 5ЕТ, будет обновлен 
новым значением. 


0: В запросе $41 на предыдущей странице два операто- 
ра =, которые используются для разных целей. Это нор- 
мально? 


| | Абсолютно. Оператор = в условии 5ЕТ означает «присвоить 
столбцу указанное значение», а оператор = в условии МНЕВЕ 
проверяет, равно ли текущее значение столбца значению, ука- 
занному после знака. 


: Могу ли использовать следующую команду для выпол- 
нения той же операции? 


ОРОАТЕ аоцднпие га1п9$ 5ЕТ бүре = 'глазиро- 
ванные' ИНЕВЕ 1Іосабіоп = 'Кг1зру Кіпд'; 


(} Да, можете. Команда внесет те же изменения в ту же запись. 
Для таблицы из четырех записей это нормально, но при работе 
с таблицей, содержащей сотни и тысячи записей, вам пришлось 
бы изменять по отдельности каждую запись, относящуюся 
кКйзру Кіп9. 


р] 
0: Можно ли убедиться в том, что обновление затронет 
только нужные мне записи? 


(} Как и в случае с командой РЕТЕТЕ, если вы не уверены 
в том, что условие ИНЕВЕ определяет только нужные записи — 
сначала выполните команду ЗЕЪЕСТ! 


0: Может ли команда содержать более одной секции $ЕТ? 


(}: Нет, но это и не нужно. Все столбцы с новыми значениями 
могут перечисляться в одном условии ЕТ, как показано выше. 
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Запьше » 


без МУЗЕРГ/ОЕГЕТЕ 


ОРОАТЕ Как замена |МЗЕВТ-ОЕТЕТЕ 


При выполнении команды УРРАТЕ из таблицы ничего не ‘удаляется. Вместо 
удаления старая запись обновляется новыми данными. 


ился с КАЮТ 
а а АТЕ-. „далее идеил имя иладлииы, со- 
< 


9 держащей обновляемцю запись. 


>ЕТ определ  ФРРАТЕ +ар1е пате 


Сил изменения, 
аа ить ЅЕТ имя столбца = новое значение 


МНЕВЕ имя столбца = старое значение; 
ы 


Условие М/НЕВЕ определяеил записи, 


6 коилорые Вносяился изменения. Команда ОРРАТЕ 
заменяет комбинацию 
ео в ІМЅЕВТ / ВЕБЕТЕ. 


Обновляеился запись 


Е из иладлицы сЇомлл тЮ 


Команд 
чевого слова 


ее ОРРАТЕ с1оип іпёо 
лисы, Р 
мрока 36. э ЗЕТ Іаѕ зееп = 'Заведение Трэйси! 


ние Трэйси’. 


ИНЕКЕ пате = 'Мистер Хобо' 
АМ 1азЕ зееп = 'Парк Диксон'; 


ловце (ди 

бос НЕВЕ а 
10сяџд Я изм [2) р 2 

Мистер х к ения Заиись вк 

сод одо, ң било 
2ержиџил Ри 9 к орой мМ случае А Рую 

аченце 'Парк ет олдец [аѕё аиись 
к -5ееи 
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деее и ирдае 


ЏРРАТЕ 8 действии 


Команда ОРРАТЕ заменяет текущее значе- 
ние столбца 1аѕё ѕееп ('Парк Диксон!) Мистера Хобо 


значением 'Заведение Трэйси". видели в <Заве- "% 
дении Трэйси». 


| Информа и 
| должна и Аоулорая 
ОРРАТЕ с1омп іпЁо Ё `` на 6 маб, ле - 


^ицц, и ком 
ЗЕТ 1азе зееп = 'Заведение Трэйси' ОРРАТЕ для её додао 
МНЕВЕ пате = 'Мистер Хобо' 
АМО 1азЕ зееп = 'Вечеринка Эрика Грея'; 


Дом престарелых Черри Ж, рыжие волосы, зеленый костюм, огромные шарики, 
Хилл ботинки машинки 

Вечеринка Джека Грина М, оранжевые волосы, синий костюм, огромные мим 

ботинки 

" Цирк ВС М, сигара, черные волосы, маленькая шляпа 


Элси 


Больница Окленд М, синие волосы, красный костюм, большой нос шарики 
Торговый центр Милстоун Ж, оранжевый костюм, штаны 


ошкола Эрла Ж, розовый костюм с блестками эквилибристика, 
машинки 


М, женское платье в горошек пение, танцы 
ние Трэйси М, зелено-фиолетовый костюм, длинный нос БГ == е8] 
оранжевый ка птаны пение 


наглз Болмарт Ж, желтая рубашка, красные штаны рожок, зонтик 
Дом престарелых Бельмонт | Ж, розовые волосы, большой цветок, синее платье | кричалки, танцы 


РТ центр Милстоун 


Ва!!-Магі 


и 29 

Д чи" Васные штаны 

9. оКа дое дгеѕѕ 
= на машинке 

ле 


Команда ОРРАТЕ бно 
<На месиле», чуло исключа 
носил удаления посилоронних данных 
ОЕ перезались сущесилвующих 
анных по-прежнему возможна). 


вил замену 
бил олас - 
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возьми в руку карандаш 
„ Возьми в руку карандаш 
ь. Обновление информации о Клоунах 


На этот раз давайте выполним обновление правильным способом. 
Напишите команду ОРРАТЕ для каждого наблюдения (мы уже написали 
одну, чтобы вам было проще). Потом запишите, как будет выглядеть табли- 
ца после выполнения всех команд ОРПРАТЕ. 


ИРРАТЕ сомит и 


Зииио илепер Ч СЕТ аснм! Нез = ‘пение! 


моёи. У/НЕЕРЕ паиле = 'Зииио"; 


Снаглз носиил 
синие щиланы. 


Бонзо видели 
парке Диксон. 


Снифлз разъєзжа т 
еил на машинке. 


Мистера Хобо 
видели на вече- 


ринке Эрика Г рея. 
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деіеќе и ирдае 


ване | ви | аррәаимә | эмм» | 
Элси Дом престарелых Ж, рыжие волосы, зеленый костюм, шарики, машинки 
Черри Хилл огромные ботинки 
Пиклз Вечеринка Джека Грина М, оранжевые волосы, синий костюм, 
огромные ботинки 


Снаглз Болмарт Ж, желтая рубашка, красные штаны рожок, зонтик 
Кларабелл Дом престарелых Ж, розовые волосы, большой цветок, кричалки, танцы 
Бельмонт синее платье 


Зиппо Торговый центр Милстоун Ж, оранжевый костюм, штаны танцы 


Автошкола Эрла Ж, розовый костюм с блестками эквилибристика, 
машинки 


И аара М СКО плате є горошек Пение, Танци 
Заведение Трэйси М, зелено-фиолетовый костюм, длинный нос 


[45 ѕеем. арреагаисе асёмтіїеѕ 

Элси Дом иресиларелых | Ж, рыжие Волосы, зеленый косилюм, | шарики, ма- 
Черри Хилл огромные доилинки шинки 

Пиклз Вечеринка Джека М, оранжевые Волосы, синий мим 
Грина космюм, огромные доилинки 


Мистер 

Хобо 

Кларабелл | Дом пресиларелых | Ж, розовые волосы, большой кричалки, 
Бельмонил ивеилок, синее плаилье иланиы 


эквилидрисили- 
ка, машинки 
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возьми в руку карандаш. решение 


Возьми в руку карандаш 
оч ие ()бновление информации о Клоунах 


Қ, 


На этот раз давайте выполним обновление правильным способом. 
Напишите команду ОРРАТЕ для каждого наблюдения (мы уже написали 
одну, чтобы вам было проще). Потом запишите, как будет выглядеть табли- 
ца после выполнения всех команд ОРР”РАТЕ. 


ИРРАТЕ соми ім Ёо 


Зииио илепере СЕТ аснм! Нез = ‘пение! вклю- 
С акб не РОИ Не забудьиле к А 
моёи. МНЕВЕ паме = 'Зимио"; аиилю 204290 инфор 
ко Ао я силолдиа 
и — она 
И НЯ а еагаисе 


не должна иоилеряй^8— 
ся ири обновлении. 


Снаглз носил Д ПРРАТЕ сом ДИ 
синие шиланы. СЕТ арреагаисе = 'Ж, желилая рубашка, 


Бонзо видели | РАГС ОИ ИТО аа пенал иная 
парке Диксон. СЕТ [а$Ё ‹ееи. = 'Парк Диксон! 


Снифлз разъезжа- 
сил на машинке. 


Мистера Хобо 
видели на вече- 
ринке Эрика Г рея. 
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аеіеќе  ирааќе 


Е ЕГИ ЕНГЕ Е 


Элси Дом престарелых Черри Ж, рыжие волосы, зеленый костюм шарики, машинки 
Хилл огромные ботинки 
Пиклз Вечеринка Джека Грина М, оранжевые волосы, синий костюм мим 
огромные ботинки 


Снаглз Болмарт Ж, желтая рубашка, красные штаны рожок, зонтик 
Мистер Хобо Цирк ВС М, сигара, черные волосы, маленькая шляпа скрипка 


Кларабелл Дом престарелых Бель- Ж, розовые волосы, большой цветок, кричалки, танцы 
монт синее платье 


Скутер Больница Окленд М, синие волосы, красный костюм шарики 
большой нос 


Зиппо Торговый центр Милстоун Ж, оранжевый костюм, штаны танцы 


Бэйб Автошкола Эрла Ж, розовый костюм с блестками эквилибристика, 
машинки 


ОЙ РЕ М, женское платье в горошек пение ЕЦЕ 
Снифлз Заведение Трэйси М, зелено-фиолетовый костюм, длинный нос 


Серые записи осилаюился неизменными. 


[4$ ее ‚ | арреагаисе асЕмтеѕ 

Элси Дом иресиларелыхиу | Ж, рыжие волосы, зеленый косилюм, | шарики, 
Черри Хилл огромные доилинки машинки 

Пиклз Вечеринка Джека М, оранжевые волосы, синий мим 
Грина косилюм, огромные боилинки 

Снаглз Болмарил Ж, желилая рубашка, (синие уииланы | рожок, зонилик 
т Ки ж 

Мистер ( Вечеринка Эрика “у |М, сигара, черные волосы, малень- |скрипка 

Ходо Пре 2—2 Ке кая шляпа 

Клараделл | Дом пресиларелых |Ж, розовые волосы, большой кричалки, 
Бельмонил ивеилок, синее платье иланиы 


Скуилер Больнииа Окленд М, синие волосы, красный косилюм, | шарики 
большой нос 
> К РИ 
Зипио Торговый ценилр Ж, оранжевый косилюм, шиланы лёние 
Милсилоцн 
Бэйб Авилошкола Эрла Ж, розовый косилюм с длесилками | эквилидрисили - 
ка, машинки 


Бонзо Парк Диксон) М, женское илаилье 6 горошек пение, иланиы 


ононе. 
Снифлз Заведение Трэйси\ |М, зелено -фиолемловый косилюм, У разъезж 
\ | длинный нос | на мам 


аеил ` 

ИНК 
Изменились илолько силолдиы, указанные в условии ЅЕТ команды Е. 
ИРРАТЕ. Наконец-ило мы заполнили ипроделы в иладлице на с. 155. 
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другие примеры ИРРАТЕ 


Обновление цен 


Помните, как мы обновляли цены в таблице аг1пк_1пЁо? Напитки 
с ценой $2.50 подорожали до $3.50, а напитки с ценой $3.50 — до $4.50. 


агіпк іпѓёо 


вю | 
ва | жельй | 
[32 | ся | 
Поцелуй д 42.5 


Лаймовый физз 


Одинокое дерево 


«аг | 
8.4 
3.2 
[86 | 
[425 | 
Горячее золото з 


Как подойти к решению этой задачи? Один из возможных способов 
с использованием команды ОРРАТЕ — перебрать все записи по отдель- 
ности и написать серию команд ОРРАТЕ следующего вида: 


ОРРАТЕ агіпк іпѓғо 

ЗЕТ соѕі = 35 Чена увеличивается на $1. 

ИНЕРКЕ агіпк пате = 'Голубая луна'; 
РА 


Условие МНЕВЕ однозначно 
иденилифииируемл обновляе - 
мые записи. 
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деее и ирдае 


«; Возьми в руку карандаш 


“ы Запишите команды ОРРАТЕ для каждой записи из таблицы аг1пкК$ іпёо, 
Г“ чтобы добавить доллар к стоимости каждого напитка. 


ему мы должны 
> Нет ли какого- 
проделывать все это вручную: падна? 
оторый мож 
ь оператора, к гея 
№ ИРРАТЕ, вместо того чтобы к 
каждую запись по отдельности: 


Минутку, а поч 


Вы правы. 


Действительно, существует удобный 
оператор, который идеально подходит 
для таких ситуаций. Давайте посмо- 
трим, как обновить цены напитков без 
ручного перебора всех записей... и без 
риска повторного изменения ранее 
измененных данных. 
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обновление нескольких записей 


Достаточно одной Команды ОРОАТЕ 


В столбце созе хранится число. В 501 с числовыми столбцами можно выпол- 
нять основные математические операции. Так, значение столбца соѕ можно увели- 
чить на 1 для каждой записи в таблице, которую требуется изменить. Вот как это 


делается: 


ОРРАТЕ дгіпк іпёо 


ЗЕТ соѕЅЕ = соѕі + 1; 


ИНЕКЕ 


Увеличииь на 1 цену 8 каж 
дой из илрех записей, комо ~ 
рые илребцеился измениило 

(налиилки за $2.50 и $5.50). 


агіпк пате='Голубая луна' 


ОВ 


агіпк паме='Вот тебе на' 


9) 3 


агіпк паме= 


+ Можно ли использовать вычита- 
ние? А какие еще операции? 


() Умножение, деление, вычитание — 
можете использовать любые из них. И ко- 
нечно, в операциях могут использоваться 
другие числа, не только 1. 


. 
• Можно привести пример с исполь- 
зованием умножения? 


() Конечно. Допустим, имеется таблица 
со списком товаров, каждый товар имеет 
свою цену. Вы можете воспользоваться 
командой ОРРАТЕ и умножить цену каж- 
дого товара на фиксированную величину, 
чтобы вычислить цену с налогом. 
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глава 3 


'Лаймовый физз'; 
Часто 


Задаваемые 


Вопісы 


О 

| Какие еще операции можно вы- 
полнять с данными, кроме простых 
математических? 


Команда ОРРАТЕ мо- 
жет работать е груп- 
пами записей таблицы. 
Используйте ее е оенов- 
ными математическими 
операторами для обнов- 
ления чиеловых данных. 


0) Их довольно много. Позднее вы 
узнаете, что можно сделать с текстовыми 
столбцами и какие еще операции могут 
выполняться с числовыми столбцами. 


В: Ну например? Хотя бы намекните. 


( Ладно — например, функция 
ОРРЕК () преобразует все значение 
текстового столбца в таблице к верхне- 
му регистру. А функция ІОМЕК () , как 
нетрудно догадаться, преобразует текст 
книжнему регистру, 


деее :: ирдае 


Хорошо, что данные можно 
обновлять. Но я хотел бы понять, 
как с самого начала правильно 
спроектировать структуру таблицы. 


Данные изменяются, поэтому 
очень важно уметь обновлять их. 


Но чем лучше будет спроектирована 
таблица при ее создании, тем меньше 
обновлений потребуется позднее. Пра- 
вильно выбранная структура таблицы по- 
зволит вам полностью сосредоточиться 
на ее содержимом. 


Заинтересовались? В следующей главе 
мы вплотную займемся вопросами про- 
ектирования таблиц. 
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ГЛАВА 3 


краткий обзор за! 


Новые нструменты 


Глава 3 скоро останется в прошлом. 
Ниже приведена краткая сводка новых 
команд 501, которые вы узнали в этой 
главе. Полный список инструментов 
приведен в приложении ІІІ. 


РЕГЕТЕ 


Команда цдаляеил. за- 
писи данных из илабли – 
цы. Использиуйиле Чсло- 
вие НЕВЕ для илочного 


определения удаляемых 
записей. 
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4 [[реекхочрование траёЛиц 


+ 
Как важно быть нормальным * 


„м тогда мама 
назвала меня своим 
маленьким помощ- 
ником! 


Да, это 
ненормально. 


р, 


жж 
7) 
веет 


| 


До настоящего момента мы не особо задумывались 
при создании таблиц. Работают — и ладно; в конце кон- 

цов, с ними можно выполнять команды ЗЕТЕСТ, ТМЗЕВТ, ЕГЕТЕ 

И ОРРАТЕ. Но при увеличении объема данных постепенно стано- 
вится ясно, что следовало бы сделать при создании таблицы для 
упрощения условий ИНЕВЕ: ее следовало бы сделать более нор- 


мальной. 


данные для рыболова 


Две таблицы 


Джек и Марк создали таблицы для хранения информации о рекордах 
рыбной ловли. В таблице Марка имеются столбцы для бытового и на- 


учного названия рыбы, ее веса и места, где она была поймана. Столб- Табл 
ца для имени человека, поймавшего рыбу, в этой таблице нет. е Чиа сосило- 
Ил из че илырех 
в олдцов. Сра- 
2 в Нииле е 
ҒіѕҺЬ іпҒо Го: ей р иладли – 
=, цей Ёр. гесокас 


На следующей 
сипранице. алач 


Монтгомери Лейк, СА 


большеротый окунь М. ѕаігпоідеѕ 22 фт 4 унц 


К 


т 
серебристый карась Лейк Ходжес, СА 6 фт10 унц 
О. Т5Намлуспа Кенай Ривер, А 97 фт 4 унц 


Я ихтиолог. В своей таблице я буду 
проводить поиск только по бытовому 
или научному названию, чтобы узнать 
вес и место вылова рыбы. 
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проектирование таблиц 


В таблице Джека тоже хранятся бытовые и научные назва- 
ния рыб, но в ней также имеются столбцы для имени и фа- 
милии рыболова, а место вылова разбито на два столбца: 
название водоема хранится отдельно от штата. 


Эила илаблица иложе содержиил 
информацию о рыболовных 

екордах, но 6 ней почили 
вовое больше силолдцов. 


Е1зп_гесог4з 229 


анан | ви | 
87950 
1л27925 


22 фт4унц | 2/6/1932 


ањ 
ое в 
лол 
9/7990 | 
палов | 


96/1990 
6 фт10 унц 
97 фт 4 унц 


А я пишу статьи для рыболовного / 
журнала. И мне нужно знать имена рыбаков, 
даты и места рекордного вылова. 


«0и в руку карандаш 


Напишите запрос для каждой таблицы, чыла 22 
возвращающий все записи для штата Нью-Джерси. 
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возьми в руку карандаш. решение 


«Возни в руку карандаш 


| Решение 
5 ҹ 


Напишите для каждой таблицы запрос, возвращающий 
все записи для штата Нью-Джерси. 


Мне почти никогда не приходится 
искать записи по штату. Я храню 
название штата в одном столбце 


Для получения резульилаилов с названием города. 


из силроки «город, шулаи» 
приходиился использоваиль 


ключевое слово ШКЕ. у 


ЅЕІЕСТ * ЕВОМ Ёл глЁо 


А мне часто при- 
ходится искать по штату, поэтому 
я выделил название штата в от- 
дельный столбец при создании 
таблицы. 


Запрос напрямую 
обраиаемлся 


| о 
к силолбцу ае. “у 


ЅЕІЕСТ * ЕРОМ Ё} кесоғаѕ 


т реи ини | ии | 
ЕТИ ЕСЕ 
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Н Выходит, таблица Джека лучше, 
чем таблица Марка? 


() Нет. Это разные таблицы с разными 
целями. Марку редко приходится про- 
водить поиск по штату, потому что его 
интересуют только названия (бытовое 
и научное) выловленных рыб и их вес. 


С другой стороны, Джеку потребу- 
ется искать данные по штату в своих 
запросах. Именно поэтому он создал 
в своей таблице отдельный столбец, 
чтобы было удобнее указывать штат 
в запросах, 


: Следует ли избегать оператора 
ТКЕ в запросах? Что в нем плохо- 
го? 


(} В операторе 11КЕ нет ничего 
плохого, но он усложняет структуру 
запроса и повышает риск получения 
посторонних результатов. Если столбцы 
содержат сложную информацию, 11КЕ 
не позволяет легко и однозначно опре- 
делить критерий поиска. 


частро 


Задаваемые 
ВопЊсьы 


|: Почему короткие запросы лучше 
дпинных? 


() Чем проще запрос, тем лучше. 

С увеличением объема базы данных 

и добавлением новых таблиц запросы 
усложняются. Начинайте с самых про- 
стых запросов, позднее вы их оцените. 


О 

• Значит, в моих столбцах всегда 
должны храниться как можно мень- 
шие фрагменты данных? 


() Не обязательно. Как показывает 
пример с таблицами Марка и Джека, 
все зависит от использования данных. 
Для примера представьте таблицы со 
списком машин, предназначенные для 
автомеханика и продавца. Механику 
необходима подробная информация 
о каждой машине, а продавцу может 


быть достаточно фирмы-производителя, 


модели и номера. 


проектирование таблиц 


|: Допустим, в записи хранится по- 
чтовый адрес. Почему бы не создать 
один столбец для хранения полного 
адреса и несколько других столбцов 
для хранения его составных частей? 


() Дублирование данных поначалу 
может показаться вполне разумной 
мерой, но подумайте, сколько лишнего 
пространства будет расходоваться 

на жестком диске, если база данных 
вырастет до значительных размеров. 
А еще при дублировании данных 

в команду ОРРАТЕ должно включаться 
дополнительное лишнее условие, и вы 
должны помнить о нем при каждом из- 
менении данных. 


Давайте более подробно разберемся 
в том, как спроектировать оптимальную 
структуру таблицы для ваших целей.. 


Структура таблицы за- 
висит от того, как вы 


собираетесь иепользо- 
вать свои данные. 


мозговой 
АН 


За — язык, используемый реляцион- 
ными базами данных. Как вы думаете, 


что означает термин «реляционный» 
в контексте баз данных 501? 
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рекомендации по проектированию структуры таблиц 


Логические связи Как суть таблицы 


ОТ, известен как язык Реляционных Систем Управления Базами 
Данных (РСУБД). Термин запоминать не обязательно, нас интересу- 
ет только слово «РЕЛЯЦИОННЫХ». Для нас оно означает, прежде 
всего, одно: чтобы правильно спроектировать таблицу, необходимо 
продумать, как столбцы связываются друг с другом для описания не- 
которого объекта. 


Ваша задача — описать объект при помощи столбцов так, чтобы по 
возможности упростить получение необходимой информации. Ко- 
нечно, выбор во многом зависит от ваших требований к таблице, но 
существуют некоторые общие меры, которые следует принять при 
выборе структуры таблицы. 


у Какой основной объекил 
Ы выверите ан объект, которы олисывагтл Ваша плаблииа? 
должна описывать таблица. 


2. Составьте список того, что необходимо 
6 6 бо Как бидеил ИбСпользо- 
знать оо этом ооъекте при ра те Раа 8 зо 


с таблицей — АСЯ ваша илаблица? 


3. Используя список, разбейте необ- 
ходимую информацию об объекте как проще всего закро- 
на фрагменты, которые могут = банные из илаблиць 
использоваться для определения 
структуры таблицы. 


* Встречается мнение, что термин «РЕЛЯЦИОННЫЙ, отно- 
сится к логическим связям между таблицами. Это неверно. 


198 глава 4 
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Сможете ли вы определить столбцы таблицы по тем словам, которыми ихтиолог 


? . 
пражнение Марк описывает выборку данных из таблицы? Запишите имена столбцов в прямо 
угольниках. 


Я провожу поиск по бытовому 
или научному названию рыбы и хочу 
узнать вес и место вылова. 


Теперь ваша очередь. Напишите аналогичную фразу для Джека, автора 
статей по рыбной ловле, который использует таблицу для получения 
подробной информации для своих статей. Затем проведите стрелки 

от каждого столбца к его упоминанию в описании. 


упражнение. решение 


Сможете ли вы определить столбцы таблицы по тем словам, которыми ихтиолог 
Марк описывает выборку данных из таблицы? Запишите имена столбцов в прямо- 


пражнение 


ТРТ" 
јооние 


угольниках. 


бытовое 
название 


Я провожу поиск по бытовомуили \ 
научному названию рыбы и хочу х © 
узнать вес и место вылова. 


Теперь ваша очередь. Напишите аналогичную фразу для Джека, автора 
статей по рыбной ловле, который использует таблицу для получения 
подробной информации для своих статей. Затем проведите стрелки 

от каждого столбца к его упоминанию в описании. 


Я хочу узнать имя и фамилию рыбака, а также дату, место вылова, 
штат и вес рыбы при поиске по ее бытовому названию. 
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Но почему мы остановились на таблице 
Джека? Ведь дату можно разбить на день, 
месяц и год? Да и место вылова можно 
уточнить до названия улицы и номера 
дома рыбака. 


Да, можно, но такой уровень детализации 
данных просто не нужен. 


По крайней мере не в этом конкретном случае. 
Если бы Джек писал статьи о том, куда лучше от- 
правиться на выходных, чтобы поймать большую 
рыбу, тогда он, возможно, указал бы название ули- 
цы и номер дома, чтобы читатели могли поискать 
жилье где-нибудь поблизости. 


Но Джека интересует только место вылова и штат, 

и он добавил только эти столбцы, чтобы не уве- 
личивать объем базы данных без необходимости. 
На этой стадии он решил, что его данные достаточ- 
но детализированы — то есть являются атомарными. 


0 мозговой 
хомо 


Как вы думаете, что означает 
термин атомарный в контексте 
данных 501? 
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Атомарные данные 


Что такое «атом»? Маленький блок информации, который невозможно (или нежелательно) 
разделить на составные части меньшего размера. Это определение относится и к данным: 
АТОМАРНЫЕ данные были разделены на наименьшие компоненты, дальнейшее деление 
которых невозможно или нежелательно. 


ДостаВКа за 30 минут, или Пицца бесплатно 


Для примера возьмем курьера, доставляющего 56 
пиццу клиентам. Чтобы выполнить свою работу, 
сму достаточно знать улицу и номер дома в одном 
столбце. Для него эти данные являются атомарны- 
ми: курьеру никогда не приходится искать номер 
дома отдельно от названия улицы. 


Более того, разбиение адреса доставки на назва- 
ние улицы и номер дома только усложнит его 

работу, а клиентам придется дольше дожидаться т 
своих заказов. 


М 
объеди- 

ес досилавки, 
Я ай номер дома 8 одном 


лиц А 
няюшщий АИ арлочно диломарен к 


огаег потег айагеѕѕ 


246 59 М. Ајах Варійѕ 
247 849 ЗОТ ЗЕгее® 
248 2348 Е. РМР Р1аха 
249 1978 НТМЬ Неідаһ+ѕ 
250 24 5. Ѕбегу1еїѕ Ѕргіпдѕ 
251 | 807 ІпҒіпібе С1гс1е 
252 32 реѕідп Раїібегпѕ Р1аға 
253 9208 5. Јауа Бапсһ 
254 4653 И. ЕЈВ Езфафе І 
255 8678 ООА&р Огсвага 
+ 
ЗЕЪЕСТ айдгеѕѕ ЕВОМ р1=ха_4е11уег1ез МНЕВЕ огаег пот = 252; 


аййгеѕѕ 


32 рез1ап Раёбегпѕ Р1аға 


+ += ++ 


гом іп зеЕ (0.04 ѕес) 
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С другой стороны 


А теперь возьмем агента по торговле не- 
движимостью. Вполне возможно, что ему 
понадобится отдельный столбец с номером 
дома — допустим, чтобы он мог получить 
список всех предложений по заданной ули- 
це. Для него название улицы и номер дома 
являются атомарными данными. 


( 


Для агенила мо илорговле недви ~ 
љжимосилью сиилуация вВыглядиил 


иначе. Оилделение номера дома 7 ме 


оил названия улицы позволии^ 
легко поличииль слисок домов, 
продаваемых на заданной улице. 


Ее Еді \МИпаом Неір МапіМуСотгтіѕѕіоп 


+ 


| зЕгееф поитрег | ѕігее пате 


+ 
59 
849 
2348 
1978 
24 
807 
32 
9208 
4653 
8678 


М. Ајах Варійѕ 

501 ЗЕгее& 

Е. РМР Р1аха 

НТМЬ Неісћёѕ 

$. Ѕегуіеїѕ $рг1п95 
Іпёјпібе Сігсіе 
Реѕідп Раёбегпзѕ Ріаға 
$. Јауа ВапсЬ 

ЗО ЗегееЕ 

ООА&р ОгсҺага 


+ 


109000.00 | арагітепі | 
115000.00 | арагітепіё 


2 гомѕ 


іп ѕе (0.01 ѕес) 
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НОЦЅЕ 
РОК ЅАІЕ 


ВУ АРРОЖМТМЕМТ ОМУ 


ргорегїу суре 


арагєтепі 
Һоиѕе 
арагітепі 
Һоџѕе 
сопао 
Воцзе 
Воцзе 
арагітепі 


ргісе 


189000 
109000 
355000 
134000 
355000 
143900 
465000 
699000 
115000 
355000 


+ 
| 


аҹ 


+ 
‘501 Ѕ+гее+' ; 
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проектирование атомарных данных 


Атомарные данные и таблицы 


Выбирая данные, которые будут храниться в ваших табли- 
цах, задайте себе следующие вопросы. 


Но олисываеил Ваша 


1.Какой ОДИН объект аса: клоунов, коров, 


пончики, людей? 
описывает ваша таблица? 


2. Как вы предполагаете 


использовать таблицу 


для получения информации Спроекилируйте илаблицы 


оее объекте? илак, чилобы заиросы были 


иросилыми! 


3. Содержат ли столбцы таблицы 
атомарные данные, 


чтобы запросы были короткими 


и конкретными? 


~ Часто 
ДадаВаеМье 


Вопсы 


Атомы совсем крошечные, верно? Значит ли это, что |: Как атомарность данных упростит мою работу? 
данные нужно разбить на мельчайшие фрагменты? 


() (} Атомарность упрощает контроль за правильностью данных 
• Нет. Атомарность данных подразумевает разбиение данных в таблице. Например, если в столбце хранятся номера домов, 
на наименьшие части, необходимые для создания эффективной можно проследить за тем, чтобы в этом столбце хранились 
таблицы, а не просто на самые мелкие части из всех возможных. только числовые данные. 


Не дробите данные сверх необходимости. Если лишние столбцы Кроме того, атомарность повышает эффективность запросов: 

вам не нужны, не добавляйте их. запросы к атомарным данным быстрее пишутся и выполняют- 
ся, что дает ощутимый эффект при хранении очень больших 
объемов данных. 
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=. Возьми в руку карандаш 


Перед вами общепринятые правила определения атомарных 
№ данных. Для каждого правила приведите два гипотетических 
примера таблиц, нарушающих данное правило. 


ПРАВИЛО 1. Столбец, содержащий атомарные данные, 
не может состоять из нескольких однотипных элементов. 


Силолдец Їл+екеѕѕ илаблицы 
Грега иу соліас+ѕ наруиаеил 
эило правило. 


ПРАВИЛО 2. Таблица с атомарными данными 
не может содержать несколько однотипных столбцов. 


Таблица еа5_Чи К 
нарцилаеи^ эи^о правило. 
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возьми в руку карандаш. решение 


Возьми в руку карандаш 
гещение 


Перед вами общепринятые правила определения атомарных 
к. данных. Для каждого правила приведите два гипотетических 
примера таблиц, нарушающих данное правило. 


ПРАВИЛО 1. Столбец, содержащий атомарные данные, 
не может состоять из нескольких однотипных элементов. 


Помниияе илаблици 
Конечно, Ваши оплвеилыь будцил ый В ней был силол- 
другими, но вом Вам пример: 


{ооб пате 


и 
р превращался 
Ябилоящий Кошмар! 


іпдгейіепіс 


мука, молоко, яйца, дрожжи, масло Здесь ило же самое: 


иредсилавьиле, Чило 

— вам поилребуеился 
найили помидоры 
8 слиске ингреди ~ 
енилов. 


ПРАВИЛО 2. Таблица с атомарными данными 
не может содержать несколько однотинных столбцов. 


огурцы, помидоры, зёхень 


Слишком Много одно ~ 


< ИРНЕ З. илииных силолдцоб! 


ый 
идей идет! 2 ${44ет13 
Мистер Говард Санджая 


206 глава 4 


проектирование табли: 


Теперь, когда вы знаете «официальные» правила атомарности и три этапа создания атомар- 


пражнение ных таблиц, взгляните на каждую таблицу, приведенную ранее в книге, и объясните, почему 
она является (или не является) атомарной. 


Таблица Грега, с. 83 


Таблица с оценками пончиков, с. 112 


Таблица с клоунами, с. 155 


Таблица с описаниями напитков, с. 93 


Информация о рыбах, с. 194 
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нормализация таблиц 


( пользе нормализации 


Ваша фирма по проектированию данных заработала, 
вы наняли новых проектировщиков баз данных 501. Атомарноеть Данных пер- 


И конечно, вам не хотелось бы целыми часами объ- 


яснять им, как работают ваши таблицы. ВЫЙ шаг на Пути создания 
Если ваши таблицы будуг НОРМАЛИЗОВАНЫ, то НОРМАЛИЗОВ АННОЙ 


они будут соответствовать стандартным правилам, 
понятным для новых проектировщиков. К счастью, таб ЛИЦЫ 
наши таблицы с атомарными данными уже наполови- , 
ну нормализованы! 


\ Теперь, когда вы знаете «официальные» правила атомарности и три этапа создания атомар- 
ных табли ‚ взгляните на ка ю табли ‚ приведенную ранее в книге, и объясните, почем 
пр ажнение Ц жду цу, приведенную р у 


она является (или не является) атомарной. 
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Преимущества нормализованных таблиц 


1. Нормализованные таблицы не содер- 
жат дубликатов данных, а это сокра- 
щает размер базы данных. Отсутствие 


дубликатов экономит 
дисковое пространство. 


2. Уменьшение объема данных, по ко- 
торым ведетея поиск, ускоряет вы- 
полнение запросов. 


Мои таблицы не так 
уж велики. Зачем мне 
тратить время на их 
нормализацию? 


Потому что даже в небольших 
таблицах выигрыш суммируется. 
К тому же объем данных увеличивается 
со временем. Если ваша таблица будет из- 
начально нормализована, вам не придет- 
ся изменять ее структуру позднее, когда 
окажется, что запросы выполняются 
слишком медленно. 
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нормализация и 1НФ 


Ненормализованные Клоуны 


Помните таблицу с информацией о клоунах? Сбор информа- 
ции о клоунах неожиданно превратился в национальное увле- 


чение, и старая таблица уже не справляется с потоком инфор- Запросы с поиском К эмим 
мации, потому что столбцы арреагапсе и асііуібіеѕ вам силолдиам получаюился 
содержат слишком много данных. Для наших целей эта табли- очень сложными — силолдиы 
ца не является атомарной. содержал СЛИШАКОМ много 


с1омп_1пЕо о ни р? 
пате | 


Элси Дом престарелых Черри шарики, 
Хилл машинки 
РОСО 
Снаглз рожок, зонтик 
Мистер Хобо скрипка 


Кларабелл кричалки, танцы 


Бэйб эквилибристика, 
машинки 
Бонзо пение, танцы 


Снифлз разъезжает 
на машинке 


г. Возьми в руку карандаш 


Давайте сделаем таблицу более атомарной. Предположим, по- 
= иск должен вестись по столбцам арреагапсе и асііуіёіезѕ, 
а также по столбцам 1аѕі зееп. Запишите более правильную 

структуру столбцов. 


(квет па с. 209. 
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На полпути КІНФ 


Даже когда таблица содержит атомарные данные, пройдена только половина пути. 
Полоностью нормализованная таблица находится в ПЕРВОИ НОРМАЛИЗОВАН- 
НОИ ФОРМЕ, или сокращенно ІНФ. 


Таблица, находящаяся в форме ІНФ, должна выполнять следующие два правила. 


ме зк зеен. Һаждая запись должна содержать 
атомарные значения. 


еилсЯ. - 


< Каждая запиеь должна обладать 


Чилобы илаблица 
дола полносилью 


“мамага, уникальным идентификатором, 


каждой записи 
необходимо при- 


отв который называетея первичным 
КЛЮЧОМ. 


о МОЗГОВОЙ 
СУШТУРМ 


Как вы думаете, какие столбцы 
хорошо подойдут на роль первич- 


ного ключа? 
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правила первичных ключей 


Правила первичных Ключей 


Столбец таблицы, который станет ее первичным 
ключом, назначается при создании таблицы. Через 
несколько страниц мы создадим таблицу и назначим 
первичный ключ, но сначала давайте повнимательнее 
разберемся с тем, какими свойствами должен обладать 
первичный ключ. 


записей. 


Первичный ключ используется 
для однозначной идентификации 


о—х 


Первичный ключ — 
столбец таблицы, 

имеющий уникальное 
значение для каждой 


Это значит, что данные в столбце первично- 
го ключа не могут повторяться. Для примера 

возьмем следующую таблицу; как вы думаете, 

какие из ее столбцов хорошо подойдут на роль 


записи. 
Еа 


первичного ключа? 


$$М (номер 
социального 


(фамилия) 


рһопе_потђег 
(телефен) 


страхования) 


о Ж 7 


Каждому человеку назна- 
Чаёился уникальный номер 
социального силрахования; 
зилоил силолдец можеил 


силаиль первичным ключом, 


будуил всилречаил 
например. 6 базе 


7 


и ю 
В эплих илрех силолдцах с высокой верояилносилью 
| ься иовилоряющиеся значения 


данных могуил дыиль записи 
‹ скол о 
нескольких людей мо имени Джон, а несколек 


у лесиле, 
людей, живущих вм А 
вые илелефоны. Верояилно, эмо не лучшие канди 


могиил имеиль одинако- 


даилы на роль первичного ключа. 


Будьте осторожны при использовании номеров 
Чдътре | социального страхования в базах данных. 


Р осторожны | 


Количество краж личных данных только увеличивается, и люди 


неохотно сообщают свои коды социального страхования — 
и вполне обоснованно. Эти данные слишком важны, чтобы рисковать ими. Мо- 
жете ли вы гарантировать, что ваша база данных защищена на 100%? Если 
нет — номера социального страхования могут быть похищены вместе с личны- 


ми данными ваших клиентов. 


проектирование таблиц 


Первичный ключ не может 
содержать мот, 


Значение МОГ! не может быть 
уникальным, потому что в других 
записях этот столбец тоже может со- 


держать МО. 
При вставке в таблицу записи без указания 
значения первичного ключа возникает 
риск создания записи с первичным ключом 
МОГ и появления дубликатов, а это нарушает 
требования первой нормальной формы. 


Первичный ключ должен быть 

компактным 

Первичный ключ должен содержать 
только ту информацию, которая обеспе- 
чивает его уникальность, и ничего более. 


Значения первичного ключа 
должны оставаться неизменными 


Если бы первичный ключ можно было 
изменять, то ему можно было бы случай- 
но присвоить уже используемое значение. 
Помните, что первичный ключ должен быть 
уникальным. 


Значение первичного ключа 
должно задаваться при вставке 
записи 


мозговой 
змее 


Сможете ли вы предложить хороший первичный ключ с учетом всех 
этих правил? 


Еще раз просмотрите таблицы, встречавшиеся нам в книге. Есть ли 
в какой-либо из них столбец, содержащий уникальные значения? 
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ещё чуть-чуть о первичных ключах 


Погодите, если я не могу использовать 
номер социального страхования, но при этом первичный 
ключ должен быть компактным, отличным от МОШ. 
о и неизменным — то что же использовать? 


Лучшим первичным ключом может быть новый 
первичный ключ. 


В том, что касается первичных ключей, лучшим решением часто 
оказывается создание столбца, содержащего упикальпый номер. 
Представьте таблицу, которая содержит все прежние данные, 

к которым добавляется новый числовой столбец. В следующем 
примере он будет называться 1р (идентификатор). 


Если бы не столбец ІР, две записи Джона Брауна были бы оди- 
наковыми, но в данном случае речь идет о двух разных людях. 
Столбец Ір обеспечивает уникальность этих записей. Таблица 
находится в первой нормальпой форме. 


в | мнение [ СИ ИЗИ 
о в | д | днн |а 


Запись Джона Брачна. 


Тоже зались Джона Брац- 
на, но силолбец 1р показы - 
баеил, чило эила уникаль- 
ная запись отлносиился 


ретин к другому Джону Брауну. 
[ля ЛюбознатоеЛьных 


В мире 501 идут ожесточенные споры по поводу использова- 
ния синтетических (то есть искусственно созданных, как стол- 
бец Ір в этом примере) и естественных ключей — данных, 


уже хранящихся в таблице (номер машины, номер социаль- 
ного страхования и т. д.). Мы не будем становиться на ту или 
иную сторону; в главе 7 первичные ключи будут рассмотрены 
более подробно. 
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часто 
Задаваемые 
Вопјъсы 


‚ Вы упоминаете о «первой» нормальной фор- н Столбец соштепез в таблице с описаниями 
ме. Значит, есть и вторая? И третья? пончиков мне не кажется атомарным. Другими 
словами, я не вижу, как удобно провести поиск 


() Да, вторая и третья нормальные формы дей- по этому столбцу. 


ствительно существуют; они определяются более (} 

жесткими правилами. Вторая и третья нормальные • Совершенно верно. Поле не особенно атомарно, 

формы рассматриваются в главе 7. но структура нашей таблицы этого и не требует. Если 
бы мы захотели ограничить комментарии заранее 
определенным набором слов, то поле могло бы 


|: Мы изменили свои таблицы, чтобы в них стать атомарным. С другой стороны, тогда поле не 
хранились атомарные значения. Какая-нибудь содержало бы искренние комментарии в произволь- 
из этих таблиц находится в 1НФ? ной форме. 


1 

() Нет. До настоящего момента ни одна из создан- 
ных нами таблиц не имела первичного ключа 

с уникальными значениями. 


Как прийти 8 НОРМУ 


Пришло время отступить на шаг и нормализовать наши табли- 
цы. Для этого необходимо сделать данные атомарными и назна- 
чить первичные ключи. Создание первичного ключа — один из 
стандартных этапов написания кода команды СВЕАТЕ ТАВІЕ. 


А вы помните, как добавить столбец 
в существующую таблицу? 
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исправление таблицы! грега 


Шсправление таблицы Грега 


После всего сказанного становится ясно, что необходимо сделать для 
исправления таблицы Грега. 


Иеправление таблицы Грега, шаг 1. Выполнить выборку всех 
данных командой ЗЕГЕСТ и как-то сохранить их. 


Исправление таблицы Грега, шаг 2. Создать новую нормализо- 
ванную таблицу. 


Исправление таблицы Грега, шаг 3. Ветавить вее старые 
данные в новую таблицу, изменяя каждую запись в соответ- 
етвии е новой структурой таблицы. 


Теперь старую таблицу можно удалить. 


Минутку, у меня полная таблица данных. И вы 
хотите, чтобы я удалил ее командой ОВОР ТАВІЕ, как 

в главе 1, и ввел все данные снова — только для того, 
чтобы создать первичный ключ в каждой записи? 


Конечно, таблица Грега не совершенна. 


> - = ) Она не атомарна и в ней нет первичного ключа. 
Д7 7 Но Грегу повезло: ему не придется пользоваться 
1%? иие старой таблицей и не придется удалять данные. 
Чтобы назначить в таблице Грега первичный ключ 
2 2 и сделать столбцы более атомарными, достаточно 
> == всего одной команды. Но сначала небольшое от- 
ступление... 
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Старая Команда СКЕАТЕ ТАВІЕ 


Таблице Грега нужен первичный ключ. После всех разговоров 
об атомарности данных Грег понимает, что он может принять 
меры для того, чтобы сделать столбцы своей таблицы более 
атомарными. Но прежде чем разбираться с тем, как исправить 
существующую таблицу, давайте вспомним, как она создавалась! 


Вот как выглядела команда создания таблицы из главы 1. 


СВЕАТЕ ТАВІЕ ту сопіасіѕ 
( 
Іаѕё пате УАВСНАБК (30), 
Ғігѕі пате УАВСНАВ (20), 
ета11 УАБСНАК (50), 
деп4ег СНАК (1), Нелезя ^и 0067 
Ьігіһаау РАТЕ, и а более 
е, ргоҒезѕіоп УАВСНАВ (50), ‘ломарнм“ 


здании 


| Іосаёіоп УАВСНАВ (50), , ницы? 


\ 
Неил иодхо- 


Зящего кан зЕабаз УАВСНАК (20), 
идама а. іпёегеѕіѕ УАВСНАВ (100), 


р 2 
Роль первич 


ного к, < зеекапа УАВСНАВ (100) 
); 


о: МОЗГОВОЙ 


‚ Хөхоә 


7; ШТУРМ 


А если старая команда СВЕАТЕ ТАВІЕ нигде не была 


записана? Как получить доступ к коду создания таблицы? 
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вывод кода СКЕАТЕ 
паблицу 
Сначала покажи денизи 


Может, для просмотра кода создания таблицы восполь- 
зоваться командой РЕЗСВТВЕ ту сопёасіѕ? Результат 
ее выполнения будет выглядеть примерно так: 


РИе Бай \Мпдом Неір Сгед51.151Адаіп 


ЕЕ 


| 1азЕ пате | уагсваг (30) 
Ғігѕі пате уагсвахк (20) 
епаі1 уагсћаг (50) 
депдех сҺагү (1) 
Ь1гЕРаау дае 
рхоЕезз1оп уагсвак (50) 


уагсћаг (20) 
уагсћһаү (100) 
уагсћаг (100) 


ѕбацѕ 
іпіегеѕіѕ 
ѕеекіп 

+ еа а сно о ае сао ае р мы А о = 


| 

| | 
| | 
| | 
| | 
| | 
1осабіоп | уахсһаг (50) | 
| | 
| | 
і | 
+ + 


Но нас интересует код СВЕАТЕ, а не описания полей таблицы. 
И нам хотелось бы узнать, как должна выглядеть исходная команда, 
не вводя ее заново. 


Команда 5НОЙ СКЕАТЕ ТАВІЕ возвращает команду СВЕАТЕ ТАВІЕ, 
которая была использована для создания таблицы (до занесения 
в таблицу первых данных). Попробуйте ввести следующую команду: 


НОЙ СВЕАТЕ ТАВЬЕ му сопёас®з; 
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Команда для экономии Времени 


Взгляните на код, который использовался для создания таблицы на с. 217, 
и приведенный ниже результат выполнения команды 5НОИЙ СВЕАТЕ 
ТАВІЕ ту сопѓбасіз. Эти фрагменты не идентичны, но если вставить 
этот код в команду СКЕАТЕ ТАВІЕ, результат будет тем же. Удалять обрат- 
ные апострофы или параметры данных не нужно, но если вы это сделаете, 
команда получится более компактной. [ 


Име ) 
Р Ра ОМОАОЦаЙ и иладлицы заключены в обраилные апосил 
а тан ОСНО 6 резульилаилах команды НОО 
к у ОЕ. счиилаёил, чило 


5 я силолдцы по ЧМол- 
СВЕАТЕ ТАВЬЕ пу сопфас®$ чанин иницидлизи = 


( руюмся значением 


а е 1. явно не 
Іаѕё паше` уагсһаг (30) аеҒаџ1іє МОЦ, и За = 


`Ғігѕё Маше` уагсВаг(20) аеЁаз1% МОТ, чение). 
`ета11` уагсһаг (50) аеҒаоі+ МОШЬ, При создании има 
`аепаег` сһаг (1) аеҒац1і+ МОЦ, блицы желаилельно 
`-ігёһаау` Чафе 4еЁаз1е МОЦ, Е ет 
`ргоЕезз1оп` уагсһаг (50) деҒаџ1ё МОБ, содержать МУ. 
`1осаііоп` уагсһаг (50) аеҒаџі+ МОШ,, 
`ѕёаёиѕ’` уагсһаг (20) аеЁаз1е МОЩЬ, 
`іпёегеѕіѕ` уагсћҺаг (100) ЯӢеҒації №1, 
`зеек1па` уагсћһаг (100) деҒао1є МОЈ, 
) ЕМСІМЕ=МуІЅАМ РЕЕАОГТ СНАВЅЕТ=ср1251 


Л 


Не обращайиле внимания на илексил 
после закрывающей круглой скобки. 
Он олисываеил механизм хранения 
данных и использчемую кодировку 


символов. Пока нас усипрояил значения Если екопировать и выпол- 
ло умолчанию 
| нить этот код, он еоздает 
Если исходная илаблица не была Е ааа м 


удалена, ило эм\ой иладлице при- —____ таблицу. 
———————ы.— 


делся присвоииль новое имя. 
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СВЕАТЕ ТАВІЕ и первичные ключи 


Команда СКЕАТЕ ТАВІЕ с назначением первичного Ключа 


Перед вами код, полученный при выполнении команды 5НОМ 
СВЕАТЕ ТАВІЕ. Мы удалили из него обратные апострофы 
и последнюю строку. В начало списка столбцов был добавлен 


столбец сопіасі іа сусловием МОТ МОШ, а в конце списка Помнииле, Чило силол- 
появилось условие РКІМАКҮ КЕҮ, в котором новый столбец беи первичного ключа 
сопсас+ іа назначается первичным ключом. не можем содержаиль 


моши Присуилетлвие 
МОШ. 6 силолёце иер - 
Вичного ключа не мо - 


зволиил однозначно 
к = иденилифицироваиль 
( а каждую запись 
-——> сопбасё іа ІМТ МОТ МЛІ,, 6 илаблице. 
Мы создали новый 1азЕ пате уагсћһаг (30) ЧеЁЕаз1е МОТ, 
силолбец соифасё- Ғігѕі пате уагсһаг (20) деҒаџ1+ МО, 
4, коилорый сила - с: 
неил первичным ета11 уагсһаг (50) деҒао1+ МОТ, 
ключом ЕТ депдег сһаг (1) деҒаџ1є МО, 
ябн 

Пре числа цни  ОБЗкЕБЧау Чаке деғаџіє МОШ, 


кальны для каждой рүоҒеѕѕіоп уагсһаг (50) деҒаџ1є МОШ,, 
записи, а илаблица 


И СЯ ДИЛО = 1осаёіоп уагсћаг (50) аеҒаџ1є МОШЕ, 

марной. з$афиз уагсћҺаг (20) аеҒаџ1+ МЈІІ, 
іпіегеѕіѕ уагсћһаг (100) аеҒаџі+ МОТ, 
зеекіта-уагсһат{100) аежаз1® мот, 


(РЕТМАВУ КЕҮ (сопбасё ій) \ 
06 = 


Здесь назначаемлся первич- 
ный ключ иладлицы. Синилаксис 
просил: за ключевыми словами 
РКІМАКҮ КЕҮ В круглых скоб- 
ках указываеился имя силолб- 
ца, коилорый будеил первичным 
ключом — В нащем примере 
эило новый силолёец соибасЕ га. 
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к алаБаеМые 


Вот[сы 


Вы говорите, что первичный ключ не может со- 
держать МОТШ.. Что еще предотвращает появление 
в нем дубликатов? 


() Прежде всего вы сами. При вставке значений в та- 
блицу столбцу сопсасї 1а присваиваются уникальные 
значения. Например, в первой команде ІМЅЕЋТ столбцу 
сопбасє 14 присваивается значение 1, во второй — 
значение 2 ит. д. 


В: Присваивать новое значение столбцу РАТМАВУ 
КЕҮ при каждой вставке новой записи весьма хло- 
потно. Нет ли более простого способа? 


(} Есть два таких способа. Первый — использование 
в качестве первичного ключа заведомо уникального 
столбца таблицы. Мы уже упоминали о том, что этот 
способ может создать проблемы (как, например, при ис- 
пользовании номеров социального страхования). 


Второй, более простой способ заключается в создании 
нового столбца с уникальными идентификаторами — как, 
например, сопсасё іа на предыдущей странице. Вы 
можете приказать своей РСУБД автоматически генери- 
ровать его значения при помощи специальных ключевых 
слов (подробности на следующей странице). 


: Для чего еще можно использовать НОЙ, кроме 
вывода команды СВЕАТЕ? 


() Команда ЗНОМ может использоваться для вывода 
информации о столбцах таблицы: 


ЗНОМ СОІ0ММЅ ЕВОМ ёар1епапе; 

Команда выводит описания всех столбцов таблицы 

с типами данных, а также другими сведениями, относя- 
щимся к конкретным столбцам. 


ЅНОЙ СВЕАТЕ РАТАВАЅЕ Яаѓараѕепапе; 
По аналогии с командой ЗНОМ СВЕАТЕ <таблица>, 
эта команда выводит код команды создания базы данных. 


ЗНОМ ТМОЕХ ЕКОМ ёар1епате; 
Команда выводит информацию об индексируемых 


столбцах и типах индексов. До настоящего момента 
из индексов нам встречались только первичные ключи, 
но скоро вы лучше поймете смысл этой команды. 


И еще одна ОЧЕНЬ полезная команда: 


ЗНОМ МАКМТМС$; 

Если на консоли выводится сообщение о том, что 
выполнение команды $01 привело к выдаче предупре- 
ждений, то для просмотра предупреждений используется 
команда 5НОМ ИАКМІМС5. 


Существуют и другие разновидности команды ЅНОМ. 
Мы рассмотрели лишь те, которые имеют прямое от- 
ношение к интересующим нас темам. 


: Для чего нужны обратные апострофы в резуль- 
татах ЗНОИ СВЕАТЕ ТАВЦЕ? Вы уверены, что без 
них можно обойтись? 


() РСУБД в некоторых ситуациях не может определить, 
что имя столбца действительно является именем столб- 
ца. Например, если имена столбцов будут заключаться 
в обратные апострофы, вы сможете использовать в ка- 
честве имен зарезервированные ключевые слова 501. 
(хотя это крайне неудачная мысль). 


Допустим, по каким-то непостижимым причинам вы хоти- 


те включить в таблицу столбец с именем зе1ес+. Такое 
объявление столбца недопустимо: 


зе1есЕ уагсһаг (50) 


А такое объявление сработает: 


`ѕе1есї` уагсһаг (50) 


О 
• А почему ключевые слова нельзя использовать 
в именах столбцов? 


(}: Можно, но нежелательно. Только представьте, каки- 
ми запутанными станут ваши запросы и сколько хлопот 
будет с вводом обратных апострофов, когда можно 
обойтись без них. Кроме того, зе1есЕ — неудачное 
имя столбца: оно ничего не сообщает о данных, которые 
в нем хранятся. 
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ключевое слово АШТО ІМСРЕМЕМТ 


1, 2, З и так далее 


Воил оно: 6 боль- 


Если снабдить столбец сопбасі іа ключевым словом минсилве реализации 
АОТО ІМСКЕМЕМТ, то РСУБД будет автоматически заполнять 581 иросило добавь - 
его значениями: 1 для записи 1, 2 для записи 2 ит. д. иле ключевое слово 


АОТО ІМСВЕМЕМТ 
(Пользоваилели М5 581 
указываюил ключевое 


СВЕАТЕ ТАВІЕ ту сопіасіѕ слово (МРЕХ с началь - 
( =: ным значением и ири 
: рашщением. За конт › 

сопіасі іа ІМТ МОТ МОМ, АОТО ІМСКЕМЕМТ, креилной информацией 


Іаѕ пате уагсһаг (30) деҒаџі+ МОЩЬ, обращайилесь к страт 


АЗ вочному руководсилву 
Ғігѕ пате уагсраг (20) ЯеҒаџіє МО, ко: М5 500. 

ема11 уагсҺаг (50) даеҒацџі+ МОЩЬ, 

депаег сһаг (1) аеҒаџі+ МОШ, У первой записи 
Ьігіһаау дафе аеҒаџ1є МОБ, 6 эилом силолдце 


" сохраняеился зна- 
ргоҒеѕѕіоп уагсВаг (50) деҒаціё МОТ, чение 1. Затем 


1осаёіоп уагсһаг (50) іеҒаџ1є МО, А силолдца 
а иломаилически 
ѕіаіцѕ уагсһаг (20) аеҒаці+ МОТ, увеличиваеился 


іпіёегеѕіѕ уагсһаг (100) деҒаџі+ МО, И 


ѕеекіпд уагсћһаг (100) деғаџ1+ МОТ, записи. 
РВІМАРВҮ КЕҮ (сопфасе 1а) 


Пока все достаточно просто. 
Но как должна выглядеть команда 
ІМЅЕВТ, если этот столбец заполняет- 
ся автоматически? Могу ли я случайно 
присвоить ему другое значение? 


Как вы думаете, что произойдет? 


А еще лучше — попробуйте и посмотрите сами. 
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Х . Напишите команду СВЕАТЕ ТАВІЕ для создания приведенной ниже таблицы, в которой 
пражнение хранятся имена и фамилии. Таблица должна содержать столбец первичного ключа с клю- 
чевым А0ТО ІМСВЕМЕМТ и два атомарных столбца. 


С 
2 Откройте терминал $01 или графический интерфейс, выполните команду 
СВЕАТЕ ТАВІЕ. 


д 


Попробуйте выполнить каждую из приведенных ниже команд ІМЅЕВТ. Обведите 
кружком команды, которые были успешно выполнены. 


ІМЅЕКТ ТМТО уоџг ёар1іе (іа, Е1г5Е пате, 1аѕє пате) 
УАЬОЕ$ (МОЬЬ, 'Марсия', 'Брэди'); 


ТМ5ЕВТ ТМТО уоџг баб1е (іа, Ғігѕ пате, 1аѕї пате) 
УАГОЕ$ (1, 'Джен', 'Брэди'); 


ІМЅЕКТ ТМТО уоџг +ар1е 
УАГОЕ$ ('', 'Бобби', 'Брэди'); 


ТМЗЕВТ ТМТО уочг бар1е (Ғігѕї пате, 1аѕі папе) 
УАЬОЕ$ ('Синди', 'Брэди'); 


ТМ5ЕВТ ІМТО уоиг_фаБ1е (ій, Е1гз® пате, 1аѕё пате) 
УА1ЈЕЅ (99, 'Питер', 'Брэди'); 


1. Все ли команды были выполнены успешно? Напишите, как будет 
выглядеть содержимое таблицы после выполнения команд ІМЅЕЋТ. 


цоии_ваБе 


(азё тамле 


иаи 
ЕЕ 
280) 
Баны 
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упражнение. решение 


| Напишите команду СВЕАТЕ ТАВІЕ для создания приведенной ниже таблицы, в которой 


пражнение хранятся имена и фамилии. Таблица должна содержать столбец первичного ключа с клю- 
— 
Ремение чевым д0ТО_ТМСВЕМЕМТ и два атомарных столбца. 
СВЕАТЕ ТАВЕЕ цоиг_фа Ме 
( 


Іа ІМТ МОТ МОШ. АОТО ІМСВЕМЕМТ, 
ВузЕ мамле МАВСНАК(20), 

[25 пате УАВСНАВ(50), 

РЕИМАВУ КЕҮ (14) 


); 


0А Откройте терминал $01 или графический интерфейс, выполните команду 
СВЕАТЕ ТАВІЕ. 


5. Попробуйте выполнить каждую из приведенных ниже команд ТМ5ЕВТ. Обведите 
кружком команды, которые были успешно выполнены. 


к 


ТМ5ЕВТ ІМТО уойбг ёар1е (ій, Ғігѕі пате, 1аѕї папе) 
УАТОЕ$ (МОБЬ, 'Марсия', 'Брэди'); 


ІМЅЕКТ ТМТО уоџг ќар1е (14, Ғігѕє пате, 1аѕі пате) 
УА1ЈЕЅ (1, 'Джен', 'Брэди'); 


"е 
ТМЗЕВТ ІМТО уочг їаріе 
УАТОЕ$ ('', 'Бобби', 'Брэди!); 


ІМЅЕКТ ТМТО уоог ёќаріе (1.5 пате, 1азе п 
АІ0ЕЅ ('Синди', 'Брэди'); 


МЗЕКТ ТМТО уочг- ГА, Е1г5© пате, 1азе папе) 
99 'Питер', 'Брэди'); 
Последняя команда 
«рабо илаёи^?: Д, Все ли команды были выполнены успешно? Напишите, как будет выглядеть 


но заменяеи^ 5 М содержимое таблицы после выполнения команд ІМ5ЕВТ. 
значение СУОЛИ 


то 1МСВЕМЕМТ. цоиг фаЩе 


ВЕ: 


Похоже, мы иоилеряли 
<— З@лись Джен, когда 
попыилались назна- 
Чииль ей индекс, уже 
назначенный Марсии! 
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" Частро 
адаВаеМые 
Вопјәсы 


: Почему первый запрос (с МОТ, в столбце іа) 
вставляет запись, хотя для іа установлено ограниче- 
ние МОТ МОТ? 


(} Хотя на первый взгляд команда выполняться не долж- 
на, сАОТО ІМСКЕМЕМТ значение МОТ, просто игнориру- 
ется. С другой стороны, без АОТО ІМСКЕМЕМТ вы полу- 
чите сообщение об ошибке, а запись вставлена не будет. 
Убедитесь в этом сами. 


ре СИ ЕК 


Знаете, это не обнадеживает. Конечно, я могу 
скопировать код из результатов $ЗНОМ/ СРЕАТЕ ТАВІЕ, 
но похоже, мне придется удалять таблицу и вводить 
все данные заново только для того, чтобы добавить 
первичный ключ. 


Вводить данные заново 
не придется; вместо этого можно 
воспользоваться командой АІТЕК. 


Таблицу с данными не обязательно удалять, 
а затем создавать заново. Структуру суще- 
ствующих таблиц можно изменить. Но для 
этого нам потребуется команда АТЕК 

и некоторые ключевые слова, описанные 
в главе 5. 
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Добавление первичного Ключа 8 существующую таблицу 
Перед вами код добавления первичного ключа АОТО ТМСВЕМЕМТ 


в таблицу ту сопбасіз. (Команда получается довольно длинной, 


так что книгу придется развернуть.) 


добавление первичного ключа 


ё члидэводи ое хех диэзииеЕ хчиэниве1ов авона ви? 
охаио: ночеаеЕ0э 1АБАд ино эж иши ‘эпицде! в кохиїпкоохен эжА ‘иэзишее киіт 
рт 32е3ч05 епдиоо оловон винаненв еснеиох еле ии 15209 ‘элэемАЬ 9 хех 


ЕС 


моз6_/5 6 < 


Юг 320м0э ууанаиии 2 


Њочух пәдүоум2 уадон к2%м2күӯроор 
паньиӯдәм воуиәуһунєУн Бипусеми 9 оумһ ‘\и0+070007 
подоумох 9 ‘Бой мМипло2 аау в90у> эаузвочу 


МҮОНЕЁ 199 ‘онумкоФ28 


№ : (РТ 32е3405) ҳдяя хччитча аач 
‘зятя тмчиччомт отач ттам 1ом ІМІ РТ 32е3чо> мийдтоо аач 


е < $32е3402 Аш этаячЕ ҸЯІТҮ 
Е < /2утумо үүмуи сту орӯоӣм эн 
У ан 0х2уђмэ СОуҮОЯОНЕ умлрвугза& Уату в 
аа А. а огонри9 ам `Бииусумм 9 оиоуоми? 70$ ибномох корон 
Ән `ОНаУ?У4отидо огодон кпн2у90000 роо 


ЭН ОмМЕ ‘54090? ог0 мл) ‘952 

- ИМ? 9 Оулоәүү эодаэм юн 
7э0уд0мл2 1990н аумимиом 
У9д2а Зита 155) 
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АІТЕК ТАВІЕ и добавление первичного Ключа 


Проверьте, как работает этот код. Откройте терминал 801. вы- 
полните команду ОЅЕ для базы данных дгедѕ 1іѕі и введите 


следующую команду: 
> АТТЕК ТАВІЕ му сопіасізѕ 
Сообщаеил, —> Арр СОБОММ сопеас® ід ІМТ №Т МОМ, АОТО ТМСВЕМЕМТ ЕТВУТ, 
чило силолбеи —> Арр РВІМАВҮ КЕУ (сопбасі іа); 


был добавлен 
в 50 записях РЕ Я Оцегу ОК, 50 гомѕ аёбесфеа (0.04 ѕес) 


Весогаз: 50 Оиріісаеѕ: 0 Магпіпдѕ: 0 
уже хранящихся 
8 нашей илаблице. 


У вас их дудеил 
меньше. 


Здорово! У меня появился первичный 
ключ, заполненный данными. Может 

ли команда АТЕВ ТАВЕЕ добавить 
столбец с номером телефона? 


Чтобы увидеть, что произошло 


Силолдец соибасе та с таблицей, выполните команду 
бклһочең в илаблицц ЗЕГЕСТ * Егош пу сопёасёз; 
первым, до всех 
осилаль 

а Ее Еді \УИпдо\м Неір А!(егаіопѕ 
силолбцов, 


Ж : ------------ +------------ 


сопбасё іа | 1аз® пате Ғігѕє пате емаі1 
гы. = -_= Ч 
3 #35. . 
З У З ә 1 | Андерсон Джиллиан 3111 апдегзопвуарвоо. 
к г 5.3 2 | Иоффе Кевин К)@з1тааоск . сом 
пы 5 4 Е: 3 | Ньюсам Аманда атмап21џуйуаћоо. сом 
< = $ я < 4 | Гарсиа Эд ей99@пуѕоѓімаге. сот 
& = 5 г Э Я 5 | Раундтри Джо-Энн јојоёуаһоо. соп 
5 ц = х 5 6 а Е 5 
35 < 55 А & 
Бх З При следующей в Напомним, ЧИЛО 
РЕЗЕ: Иощей Осилавке новой зад е конец 
хое 9.5 СОлЁасё гА бцдеил иси силолбцц эило еще Н 
а те: присвоено значени . ц Грега 
2 $аа 5 ‘иее максимального значен Ниё, на 1 доль ~ илаблииьб Ч ' Ё 
р а кы це. Если у последней зарини 260.14 6 иладли- много знакомо: 
я записи А 
содержиил значение 25, ило тец сол+асё іа 
он дудеил равен 24. У СЛе0уноцей записи 


Получит ли Грег свой столбец с номером телефона? Об этом вы узнаете в главе 5. 
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ГЛАВА 4 


краткий обзор 54! 


Новые инструменты 


Вы взяли на вооружение материал главы 4. Только 
посмотрите, сколько у вас появилось новых 
инструментов! Полный список инструментов приведен 
в приложении 11. 


Атомарные данные 


Данные силолб 
назы- 
Ваюился о ца назы 


Е марными 
Е если они раздиилы на’ 
герт д наиМеныд 
Силолбец» ор не мо ар 
анне» а 
оси 
| С лалныХ элемени^о 
2 Команд 
: атт выводиил ира - 
М г ыми данне! создания Е 
аж е? к сущесилвующей 
Таблица е а = 
Рек ил содер сулолбиов ицы. 
сколеко 


Первичный ключ 


Силолбец или набор силолӧ - 
цов, значение коилорого 
‘однозначно иденоичии- 
руеил запись 6 иладлице. 


команды нениц 
ки 2ен 
Уника ерирце 
е 
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Возьми в руку карандаш 
Б" Решение 


Давайте сделаем таблицу клоунов более атомарной. Предположим, 
поиск должен вестись по столбцам арреагапсе и ас* 11 1ез, 
а также по столбцам 1азЕ_ ѕееп. Запишите более правильную 


структуру столбцов. 


Здесь неил единсилвенного правильного оилвеила. 


Факилически лучшее, чило можно сделатль — 
эило Выделииль В отлдельные силолдиы илакие 
аилрибуилы, как пол, ивеил косилюма, ивеил 
ишиланов, илим шляпы, музыкальный инсилруменил, 
шарики (да/неил), пение (да/неил)? иланцы 
(да/неил) и ил. д. 


Чилобы илаблица была аиломарной, разные виды 
дейсилвий и элеменилы внешнего вида нужно 


разделииль по разным силолдиам. 


Придавьиле дополниилельные баллы, если 


бы решили разделииль силолбеи месилона- 
хождения на шилаил, город и улицу! 
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АНИ 


+ 
+ Как изменить прошлое + 


Если бы я мог вер- 
нуться в прошлое, 
я бы выбрал другой 
шампунь. 


Вам никогда не хотелось исправить прошлые ошиб- 
КИ? Что же, теперь у вас есть такая возможность. Благодаря команде 
АГТЕВ вы сможете применить свои новые знания к таблицам, создан- 
ным много дней, месяцев и даже лет назад. А самое замечательное, 
что это никак не повредит существующим данным! К настоящему мо- 
менту вы уже знаете, что означает понятие нормализованный, и мо- 
жете применять его ко всем таблицам — как прошлым, так и будущим. 


модификация таблиць! грега 


Нужно Внести пару изменений 


Грег хочет внести в таблицу некоторые изменения, 
но так, чтобы не потерять существующие данные. 


--+- 


| сопфасЕ іа 1азЕ пате | 1х3 пате | ета11 
+ 1 } } 
Андерсон Джиллиан 3111 апдегѕопёуаћһоо 


Иоффе Кевин Хх) @=51таадиск . сом 
Ньюсаме Аманда амап21оџуёуаһоо. сом 
Гарсиа Эд ей99ёпуѕо#імаге. со 
Раундтри ‹ Джо-Энн јојоёуаћоо. сом 


Значит, я все-таки могу до- 
бавить столбец с номером 
телефона? 


Да, он легко добавляется 
командой АІТЕК ТАВІЕ. 


Более того, нам кажется, что вам 
стоит сделать это самостоятельно, 
потому что вы уже знакомы с коман- 
ДОЙ АІТЕК. Чтобы узнать, как выгля- 
дит код команды, выполните следую- 
щее упражнение! 


АІТЕР 


г. Возьми в руку карандаш 


Б% Взгляните повнимательнее на команду АІ ТЕК ТАВІЕ, использо- 
`. ванную для добавления первичного ключа в главе 4. Удастся ли вам 

составить свою команду АГТЕВ ТАВІЕ для добавления столбца 

с номером телефона из 10 цифр? Учтите, что в новой команде не 

обязательно использовать все ключевые слова из приведенного 


примера. 
АЦТЕК ТАВЬЕ ту сопфас®$ 
Арр СОБОММ сопбасі іа ІМТ МОТ МО АОТО ТМСВЕМЕМТ ЕТВЗТ, 


Ар РЕТМАВУ КЕҮ (сопфасе іа); 


Запишите свою команду А1ТЕК ТАВІЕ: 


Вы также можете задать местонахождение нового столбца в таблице при помощи ключевого слова 
ДЕТЕК. Попробуйте определить, где должно находиться это ключевое слово, чтобы новый столбец 


был добавлен после столбца Ё1г5Е папе. 


Запишите новую версию своей команды АІТЕК ТАВІЕ: 


возьми в руку карандаш. решение 


г. Возьми в руку карандаш 


гешение Взгляните повнимательнее на команду АІ. ТЕК ТАВТЕ, использо- 
==. ванную для добавления первичного ключа в главе 4. Удастся ли вам 
составить свою команду АІ ТЕЕ ТАВІЕ для добавления столбца 
с номером телефона из 10 цифр? Учтите, что в новой команде не 
обязательно использовать все ключевые слова из приведенного 
примера. 


АЬТЕВ ТАВІЕ ту сопфас®з 
АБР СОГОММ сопіасі іа ІМТ МОТ МОЦ. АОТО ТМСВЕМЕМТ ЕТВ$Т, 


Арр РАТМАВУ КЕҮ (сопбасё +9); "8 7 бА 


Ключевые слова МОТ МОШ, 
АЧТО1МСВЕМЕМТ и ЕІРЅТ 


Запишите свою команду АГТЕВ ТАВІЕ: 9 
АХ 8 новой команде не используюился. 


Изменения, как и прежде, Вносяился 
8 илаблииц илу солёас#5. 


„АЦТЕК ТАВЕЕ илу сомёасѕљ Е 7%...Бидем счиилаиль, чило 
АРР СОГОММ риоие МАКСНАК(10); длина илелефонного 
ТНТ ен иа оенд не иребвы - 
ИВ . Грег 
Эилоил фраг сооб- Имя нового И: 


щаеџл команде АІТЕР силолдия. 
какие изменения ы 


Носяился 6 илаблииц. 


фонах из других 
силран. 


Вы также можете задать местонахождение нового столбца в таблице при помощи ключевого слова 
АЕТЕВ. Попробуйте определить, где должно находиться это ключевое слово, чтобы новый столбец 
был добавлен после столбца Е1г5Е пате. 


Запишите новую версию своей команды АЪТЕВ ТАВІЕ: 


Условие АРТЕК не обязаилель- 


— 
Ключевое слово АЕТЕВ © именем сиилсилвиеил, 
силолдца, за коилорылм должен сле- но. Если оно 0\^с9 У 


доваиль новый силолдец. Таким об- о 
разом, силолдец риоие 6 иладлиие о 
следцеил за силолбиом Визе маиле, 
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Наряду с ключевыми словами ЕТВ$Т И АЕТЕВ при 

вставке столбцов могут использоваться ключевые | 

слова ВЕЕОВЕ и ІАЅТ. За сценой у 
А также ЅЕСОМР”, ТНІРВр и так далее. 


—— =) Магнахоы с Кодами 

2252 

27 Измените позицию добавляемого столбца рћопе при помощи магни- 
тов с ключевыми словами. Создайте как можно больше разных команд, 
запишите состояние столбцов после их выполнения. Конструкция 


ВЕЕОВЕ в Му50І не работает; довольствуйтесь ЕТВ$Т и АЕТЕВ. 


сопіасї іа Іаз? поте | сома 19 | Па пате | Низ пате | етай 


АГТЕВ ТАВІЕ арн 
АБО СОГОММ рһопе УАВСНАВ (10) 


АГТЕВ ТАВІЕ ту сопфасез 
АР) СОГОММ рһопе УАВСНАВ (10) 


АГТЕВ ТАВІЕ пу сопёасізѕ 
АР) СОГОММ рћһопе УАВСНАК (10) 


сопёас? 19 рһепе | Прв? пато 


АТТЕК ТАВІЕ ту сопфасе$ 
АБР СОГОММ рһопе УАВСНАВ (10) 


| ет) Г) (ео 


Добавьиле свои 


магниилы 8 конец 
команды | 8 


Используйиле аа <<;> 
везде, где лоилребуеился. 
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разелечения с магнитами. ответ 


Магниты с Кодами 


Измените позицию добавляемого столбца рћопе при помощи магни- 
тов сключевыми словами. Создайте как можно больше разных команд, 
запишите состояние столбцов после их выполнения. Конструкция 
ВЕҒОКЕ в Муѕ50! не работает; довольствуйтесь РІРЅТ и АЕТЕВ. 


С ключевым словом ЕІЁЅ$Т 


| силолбеи рћоље размешща - 
ЕНЕМЕ асрет сакри #— емся перед всеми осилал ~ 


АРр СОГОММ рһопе УАВСНАВ (10) и Неми силолбцами. 


АГТЕВ ТАВІЕ шу сопбасёз С ключевым сло - 


АБР СОГОММ рһопе УАВСНАВ (10) С БЫ аай А 
а – 


ейл 
АТЕВ ТАВІЕ шү соп®асез ся после всех 


я осилальных силолб- 
Арр СОЦЈММ рһопе УАВСНАВ (10) ЕСИ ЕШ. < (08 То же ироис- 
ходиил ири исиоль- 
АГТЕВ ТАВІЕ шү сопбасіз 2. З0вании ключевого 
АБР СОБОММ рћопе УАВСНАВ (10) Р: слова НЕТН и без 
Чказания позиции. 


С ключевым словом 
АТЕВ ТАВІЕ шу сопіасёзѕ ЅЕСОМР” силолбец 
поле размещаеился 
АБР СОЦШОММ рћопе УАВСНАВ (10) | ЗЕСОмо аер. 
Р (10) Е ЮС: | | во вилорой позиции; 
ио же ироисходиил 


АГТЕВ ТАВІЕ шу сопёасіѕ 
— ири использовании 


АОР СОТОММ рһопе УАВСНАВ (10) кАРоНаВо2о СОВА 
ВЕРОКЕ (с именем 

ВЕҒОВЕ Іаз+ 
оне (зане пала ЕИ. силолдиа (а маиле). 


єопїасї_ іа рћопе 105? пате ге? пате 


Консилрукция АҒТЕЕ (аѕЕ мамле 
ВРЕЕБ САБРЕ лау а размеидаеил силолдец риопе 


АБР СОГОММ рһопе УАВСНАВ (10) 6 илрепльей позиции. Если бы 


8 наборе был магниил ТНІКР, 
} = ило он сделал ды ило же самое. 


тәнне а | ан нене [| оне | беленә әвен | 
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АІТЕР 


Шзмененце таблиц 


Команда АТЕВ ра ач і 1 е А1уегаёіорѕ 


позволяет изме- 
Обслуживание сушествующих табли; 


нить практически 
любые атрибу- 

ты таблицы без 
необходимости 
повторной встав- 
ки данных. Будьте 
осторожны: изме- 
нение типа данных 
столбца может 
привести к потере 
данных. 


СНАМСЕ — изменение имени и типа данных столбцов * 


МОП ТОУ - изменение типа данных или позиции 
столбцов * 


АРр — добавление столбцов в таблицу (тип данных 
по выбору заказчика) 


Одно маленькое! 


рвОрР - удаление столбцов из таблицы * изменение, это 
совсем не больно. 


* Возможна потеря данных, зараноия 
не предоставляется. 


ДОПОЛНИТЕЛЬНЫЕ УСЛУГИ 


Изменение порядка столбцов 


(только при использовании АОО) 


мозговой 
ШТУРМ 


ргојекіез 
Какие изменения могут потре- 


боваться в этой таблице? [тәнә 2есеіранебәғай [ пожетвазитожрь 


а Геовельные работы | Джексон | 
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капитальный ремони: 


Служба ремонта таблиц к ва- 
шим услугам! В наших руках 
даже негодная таблица преобразится 
и станет настоящей гордостью вашей 
базы данных! 


Капитальный ремонт таблицы 


Начнем с таблицы, которая явно нуждается 
в серьезной переработке. 


Не содержиил ин- в 
формации о илом, А 
какие данные долж ~ 


ЫХ 


ны а РА 7 
- й иладлиие. | 
Название и в "е ц еб 4 < 
ца ничего о і подчеркивания имя к 
говории^ 0 силолдца силанеил | 
содержимом: К долее ИОНЯИАНЫМ и 
— =. ргојекіѕ 


вчанәеГаалазйәнара оон | 


укладка паркета 
кровельные работы Джексон 


Имена илаблицы и силолбцов 
осилавляюил желать лучшего, 
но с данными все 6 порядке. 
Давайте воспользуемся командой РЕЗСКТВЕ и посмо- Нам хоилелось ды их сохранииль. 
трим, какую структуру имеет таблица. Из ее резуль- 

татов мы узнаем, есть ли у таблицы первичный ключ 

и данные какого типа хранятся в каждом из столбцов. 


РИе Еак УМпаом Нер ВааТабереѕідп 


--> рЕЅСВІВЕ ргозек®5; 


іп+ (11) 
| аеѕсгірііопоѓёргој хагсћаг (50) 
| сопёгасёоксопјоЬ уагсвах (10) 
+---=---------------- +---------=--- 
3 гомѕ іп зеЕ (0.01 зес) 
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АІТЕК 


Переименование таблицы 


У таблицы в ее текущем состоянии имеются свои недостатки, 
но с помощью команды АІТЕК мы сделаем ее пригодной для 
хранения списка работ по ремонту дома. Начнем с присваивания 
таблице осмысленного имени командой АТТЕВ ТАВІЕ. 
<рго]еКЕ5>» — силарое 
имя иладлииы. 


БЕ 


АГТЕК ТАВЬЕ ргојекёз 
ВЕМАМЕ ТО ргојесі 113%; 


—— №. 
а Кд «ргојес |> — новое имя. 
линин коилорое мы ирлеваиваем 
НЕРЕИМЕНОВАТЬ: иладлиие. 


Что еще следует сделать для улучшения таблицы? Найдите в описании клю- 
чевые пункты предполагаемого использования таблицы, после чего заполните 


пражнение названия столбцов. 


Чтобы таблица стала НОРМАЛИЗОВАННОЙ, мы добавим 


О в нее первичный ключ с уникальным идентификатором 


проекта. Также нам понадобятся столбцы для описания 


каждого проекта, даты начала работ, примерной стоимости, 


названия компании-подрядчика и номера телефона, 


р ый У = 
==) 
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упражнение. решение 


Что еще следует сделать для улучшения таблицы? Найдите в описании клю- 
чевые пункты предполагаемого использования таблицы, после чего заполните 
названия столбцов. 


пражнение 
|бешение 


Не огорчайтесь, если Ваши 
имена силолдиов не совиадаюил 
с приведенными. Сокращения 
бопусилимы, если они не ис 


кажаюил смысла х 
Е В анимых 
Убедиилесь В илом, чило корои данных. Р 


4) 
е имена (илакие, как рѓој- 
доди поняилны вам и другим 


иользоваилелям е, 
базы данных. 


: 


! 
Чтобы таблюща стала НОРМАЛИЗОВАННОЙ, мы добавим 
соп пате = 


в нее ервичный клю9% уникальным идентификатором 


проекта. Также нам понадобятся столбцы дл описания» 


каждого проекта(дат мачала работбримерной стоимости 


ГУТ" омера телефонӣ % 


Е 


240 глава 5 


АІТЕВ 


Грандиозные планы 


ргојесі 1ізё 


Г аозейрневеївеәг | сәхнанәгәнБь | 
покраска дома 


Данные трех новых столбцов уже хранятся в таблице. 
Вместо того чтобы создавать новые столбцы, мы переиме- 
нуем уже существующие столбцы командой КЕМАМЕ. Это 


позволит нам избежать повторной вставки данных в новые 
столбцы. 


о МОЗГОВОЙ 
М 


Какой из существующих столбцов станет 
хорошим кандидатом на роль первичного 
ключа? 
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изменение столбов 


ПерепланироВКа столбцов 


Итак, план действий составлен. Теперь мы можем изменить 
существующие столбцы командой АТТЕВ И привести их в соот- 
ветствие с новой схемой назначения имен: 


=> поптрег преобразуется в первичный ключ ргој іа 


[+ ЯдезѕсгірііопоЁргој преобразуется в столбец с описа- 
нием проекта ргој_деѕс 


> сопігасіогопјор преобразуется в столбец с названи- 
ем компании-подрядчика соп патње 


Остается добавить в таблицу три столбца с именами езі созі, 
соп рћһопеи ѕќагё даѓе. 


анияме 


ИА ( о 97 
и )» 
Ос 


Дес. 


д назы 


мроєкелоо : 


баилься рео] 
ргојесі 1ізѕі а 


А 


Первый силолбец пере- 
Силолдцу с назва 


именовываеился 6 рис] 1. 


Он силанеил первичным комланиц-додр ии 
Ябчи 

ключом илаблииы. пРисваиваеился илл А 
сои. пале Я 


ргојесї 1ізѕі 


ет ЫГ. 
агч НИ ЕЕ 
ЕТУ АЕ ГоеоСВСИВЕЕЙ 


АІТЕВ 


Структурные изменения 


Мы решили переоборудовать существующие столбцы под 
три из шести столбцов, предусмотренных запланированной 
структурой таблицы. Кроме переименования, также следует 
обратить внимание на тип данных каждого из этих столбцов. 


Взгляните еще раз на структуру таблицы. 


Рие Бай У/пдом Нер ВаатТабіереѕідп 


--> РЕЗСВТВЕ ргојекіёѕ; 


іп (121) 
деѕсгірііопоёргој уагсћах (50) 
сопігасіогопјоЬ уагсћһаг (10) 
+ ------------------- 
3 гом5ё іп ѕеё (0.01 зес) 


о мозговой 


СТ ШТУРМ 


Проверьте типы столбцов и решите, соответ- 
ствуют ли они тем данным, которые мы соби- 


раемся хранить в таблице. 
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команды АЕТЕР и СНАМСЕ 


АІТЕВ и СНАМСЕ 


На следующем шаге мы присвоим столбцу попег новое имя ргој іа и устано- 
вим для него атрибут АОТО ІМСКЕМЕМТ. Затем столбец будет назначен первичным 
ключом. Описание звучит устрашающе, но на самом деле все очень просто. Более 


того, задача решается всего одной командой. 


На эилоил раз использцеил- 


А СНАМСЕ Не забудоиле, 
ТУРНАЙ ОЕ, Чило мы чило илаблице ги силолдец заполня - 
и а, а было присвоено «ргој 14> — но- еился авиломаиличе - 
коилорый ранее А Ра новое имя. вое имя, коило- И 
(атон 0 и рое присваива- и 
С еился силолбцу. ЎА значений МОЦ. 


х АТЕВ ТАВЦЕ ргојесі 11$5е 
СНАМСЕ СОІ0ММ потрег ргој іа ІМТ МОТ МОГ. АОТО ТМСВЕМЕМТ, 
АПР РЕТМАВУ КЕҮ ('ргој ій'); 


Эила часиль команды приказываеил 
РСУБД использоваиль силолдеи 


с новым именем ркој 1 
8 качесилве первичного ключа. 


<. Возьми в руку карандаш 


к < ной команды. 


Изобразите структуру таблицы после выполнения приведен- 
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(ъвет па с. 269. 


АІТЕВ 


Изменение двух столбцов одной Командой $01 


А сейчас мы изменим не один, а целых два столбца всего одной командой. Столбцы 
дӢеѕзсгірііопоЁргој и сопігасіогсопјор будут переименованы одновременно 

с изменением их типов данных. Все, что для этого потребуется — включить в коман- 
ду АГТЕВ ТАВІЕ две строки СНАМСЕ СОІОММ, разделив их запятой. 


А450їрніотовркој = и р - 
ое олов, 
каноре САВА, Е и 8 не 
Злой командой Ё «Рүој_йе5с» — можно было хра- 
| новое имя нииль более длин- 
| | силолдца... ные описания. 
АГТЕВ ТАВІЕ ргодес® 115% А д 


СНАМСЕ СОШОММ дӢезсгірііопоЁргој ргој дезс УАВСНАК (100), 
СНАМСЕ СОІЈММ сопігасёогопјор соп пате УАВСНАВ (30); 


Г 1 7 
Другое силарое 
имя силолбиа, „новым именем сом маиле, 
«сом+гасоғоијоб», а эило новый илии данных. 
иложе бидеил заме ~ 
нено... 


Преобразование столбца к новому типу данных может 
Чдътре | привести к потере информации. 


остроРожЖНы. Если новый тип данных несовместим со старым, то команда не вы- 
: полняется, а РСУБД сообщает об ошибке в команде. 


Но что еще хуже, если старый и новый типы совместимы, может произойти усече- 
ние данных. 


Например, при преобразовании столбца уагсраг(10) к типу сһаг(1) значение столбца 
'Бонзо' превратится в 'Б'. 


То же относится и к числовым типам. Тип столбца можно сменить, но данные 
будут преобразованы к новому типу, а это может привести к частичной потере 
информации! 
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ключевое слово МОГ!Е-У 


А если я хочу изменить тип данных столбца (например, 

чтобы в нем помещалось больше символов), но при этом оставить ему 

прежнее имя — я могу просто повторить имя столбца, верно? Вот так: 
АТТЕВ ТАВІЕ туТаб1е 

СНАМСЕ СОЪОММ шуСо1итп туСо1 отп МЕМТУРЕ; 


Конечно, такой способ работает, 
но есть и более простой путь. 
Воспользуйтесь командой МОРТЕУ. Она меня- 


ет только тип данных столбца, оставляя неиз- 
менным его имя. 


Допустим, вы хотите увеличить длину столб- 
ца для хранения данных ргој Яеѕс до 
УАВСНАК (120). Это делается так: 


АГТЕВ ТАВІЕ ргојесі 115% 
МОРІЕҮ СОГШОММ ргој деѕс УАВСНАВ (120); 


Имя изм —^ Новый илии данных: к 
силолдца Мого а 
а И не задудьмле проследииль за илем, 
чилобы новый илии не привел 
к чсечению счилесилвующих данных! 
часто 
адаваемые 
Вот[сь 
‹ Аеслия захочу изменить порядок столбцов? Могу ли ‚ Но разве хранение столбцов в неправильном порядке 
я выполнить команду: АТЕВ ТАВЬЕ МООТЕУ СОГОММ не создаст проблем? 
ргој дезс АЕТЕК соп пате; 
(} (); Нет, потому что в команде ЅЕТЕСТ можно указать порядок 
• После того как таблица будет создана, порядок столбцов вывода столбцов в результатах запроса. Неважно, в каком 
изменить невозможно. Фактически лучшее, что можно сделать — порядке хранятся данные на жестком диске; вы всегда можете 
добавить новый столбец в нужной позиции и удалить старый, использовать запись вида: 


но тогда все данные в старом столбце 6 потеряны. 
8 Б р несир" Р? ЗЕЪЕСТ со1отп3, со10тпі РВОМ уоџг ќар1е; 


или: 


ЅЕЕСТ со1џтп1, соІолл3 РВОМ уоџг аре; 


или получить столбцы в любом другом порядке. 
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АІТЕР 


Я говорю по телефону со 
, своим агентом. Добавьте 
пражнение остальные столбцы само- Ргојесїі 113% 


стоятельно, хорошо? 


о 


В таблицу необходимо добавить еще три столбца: для хранения телефо- 
на, начальной даты и примерной стоимости работ. 

Напишите одну команду АІТЕК ТАВІЕ, которая добавит эти столбцы; 
обратите внимание на типы данных. Затем заполните приведенную ниже 
таблицу. 


ргојесї 1ізі 
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упражнение. решение 


е нар А еа 


Я говорю по телефону со 


х своим агентом. Добавьте 
р ажнение остальные столбцы само- ргојесі 113% 
ММеНИЕ оу столтельно, хорошей У Грета ргааане вене | 


о 


аса ЕА АЈА ЕР Ра 
ВЕН саа БЕБЕ 
В РЫСЬ ЗЕЕ 


В таблицу необходимо добавить еще три столбца: для хранения телефо- 
на, начальной даты и примерной стоимости работ. 

Напишите одну команду АТТЕВ ТАВІЕ, которая добавит эти столбцы; 
обратите внимание на типы данных. Затем заполните приведенную ниже 
таблицу. 


В силолбие МА 
из 10 


СИлиил 


КСНАЮВ 
символов ломе _ 


СЯ код города. 
АЁТЕК ТАВЬЕ ркојес ёабіе 


АРР СОЁЕОММ сои рћопе МАВСНАВ(1.0), 


Мы добавляем 
новые силолбиы, —= Арр СОЁБОММ ѕёагі дае РАТЕ, 


лоэилому исполь ~ 
зуеился АРр. “> Арр СОГОММ е5Е со РЕСІМАІ (7,2); 


Наиомним, чило эило поле 
РЕС сосилоиил из 7 цифр, 
с 2 цифрами 8 дродной часили. 


рго)ес®Е_ 1ізіё 


И тя и Ч УМ 


050803262 Аа СЕБЕК 
а Е Е 
Е) равана БЗНАНАЗИ ЕН БиОИОННАТ 
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АЕТЕЮ 


Стоп! 
Никаких лишних столбцов! 


Только что выяснилось, что наш проект вре- 
менно приостановлен. В результате столбец 
згагі дасе можно удалить из таблицы. Нет 
смысла хранить в базе данных лишнюю ин- 
формацию, которая только попусту занимает 
место. 


В таблицах рекомендуется держать только 

те столбцы, с которыми вы действительно 
работаете. Если столбец не используется, 
удалите его. Если он вдруг снова понадобится 
вам в будущем, его можно будет легко добавить 
командой АГТЕВ. 


Чем больше столбцов в таблице, тем большую 
работу придется проделать РСУБД при обра- 
ботке запросов и тем больше места занимает 
база данных. Возможно, при малом объеме 
данных это незаметно, но с увеличением 
объема таблицы задержка при получении 
результатов становится более ощутимой. 


Возьми в руку карандаш 


“ 


Напишите команду $ОЕ для удаления столбца зфаге даёе. 
Мы еще не описывали ее синтаксис, но вы все равно попы- 
тайтесь. 
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возьми в руку карандаш. решение 


„. ВОЗЬМИ в руку карандаш 


Ие, Напишите команду 501 для удаления столбца загі Чате. 
Мы еще не описывали ее синтаксис, но вы все равно попы- 


тайтесь. 


х 


Имя иладлицы. 


те 
АТЕК ТАВІЕ ргојесї_їаре 


ОКОР СОШММ стагі даіе; 


Силолбиы чдаляюился 303 К Р 
командой РКОР. Проще Имя удаляемого 
иросмого! Ад 


т? Все данные, хранившиеся 
[м дье | в удаленном столбце, теряются! 


: осторожны, Будьте очень внимательны при исполь- 

зовании ВОР СО10ММ. Возможно, сначала 
стоит выполнить выборку данных из столбца, который вы 
собираетесь удалить, и убедиться в том, что в нем дей- 
ствительно нет ничего нужного! Лучше хранить в табли- 
це лишние данные, чем лишиться жизненно необходимой 
информации. 
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АІТЕВ 


Пришло время превратить вашу ста- 
рую, скучную таблицу в настоящую 
«бомбу». Вы и не подозревали, что 

такие превращения возможны! 


пражнение 


Итак, мы возьмем жалкую второсортную таблицу с данными подержанных 
автомобилей и командой АТТЕВ преобразуем ее в новенькую и сверкаю- 
щую. Задача усложняется тем, что хранящиеся в таблице данные должны 
остаться неповрежденными. Готовы к испытанию? 


Дополнительные баллы, если вам удастся все сделать в одной команде 
АГТЕВ ТАВІЕ. 


Һоорііе 


1998 17992 540 
миг | 2000 15955 
2002 Саас 40215.9 


КОСАЕВ саг +ар1е 

КМКІК66М33С213481 серебристый | _ 1998 17992.54 
5АЕРА44В175804113 П 2000 15995.00 
ЗСҮЕКӨЗМТ26280668 | Садас красный 2002 40215.90 
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упражнение. решение 


Пришло время превратить вашу ста- 
рую, скучную таблицу в настоящую 
«бомбу». Вы и не подозревали, что 
такие превращения возможны! 


|е2мение 


Итак, мы возьмем жалкую второсортную таблицу с данными подержанных 
автомобилей и командой АГТЕВ преобразуем ее в новенькую и сверкаю- 
щую. Задача усложняется тем, что хранящиеся в таблице данные должны 
остаться неповрежденными. Готовы к испытанию? 


Дополнительные баллы, если вам удастся все сделать в одной команде 
АТТЕВ ТАВІЕ. 


Һоор+іе 


108 7992540 
ми | 2000 15995 
2002 СадИас 40215.9 


саг_фаЪ1е 
[_ моё! | союг | уөаг | ргісе | 


ЅАЕРАА4В175ВО4113 моц. 2000 15995.00 
ЗСҮЕКӨЗМТ2С280668 | СадИас 2002 40215.90 
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АЕТЕЮ 


РЕЅСКІВЕ и прове и 
данных всех силолдиов д 
Эило поможеил издежаиль 
возможной иоилер 


МТЕК ТАВІЕ оре А 

КЕМАМЕ ТО саг аре, 

АІТЕК ТАВІЕ саг +гЫе 

АБО СОШММ саг 14 ІМТ МОТ МИЦ. АОТО 1МСРЕМЕМТ ЕІВ8Т, 

АО РЕМАКУ КЕҮ (саг 14), 

АБТЕВ ТАВІЕ саг іае АЩ 


после чего силолдиы 
<«<соіоғ» и «цеаи» разме ~ 


Аро СОШММ ММ УАСНАР (16) ЅЕСОМО, онат 
СНАМСЕ СОШММ по мое! УАВСНАЕ (20) <” 
25 


Переименованному силолбиц 
<илоае|> назначаеился новый 


МОРІҒҮ СОШММ со|ог АРТЕК тойеі, ИОАНН, 


Также можно было использо - 


МОРІҒҮ СОШММ уеаг $1ХТН, < ^^ бамо консилрукцию «усаг АРТЕВ 


ило4е|> или «цеаг ВЕРОВЕ рисе>». 


СНАМСЕ СОШММ һомтисћһ ргісе РЕСІМАЦ7,2); 
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часто задаваемые вопросы 


часто 
Задаваемые 


Воть 


: Ранее вы говорили, что я не могу изменить порядок сле- 
дования столбцов командой МОРІЕҮ, а моя РСУБД позволя- 
ет мне переставить столбцы. Как она это делает? 


() Ваша РСУБД незаматно для вас выполняет сразу несколько 
операций. Она копирует значения из перемещаемого столбца, 
сохраняет их во временной таблице, удаляет перемещаемый 
столбец, изменяет таблицу и создает новый столбец с таким же 
именем, как у старого, копирует в него данные из временной 
таблицы и удаляет ее. 


Если столбцы уже содержат данные, а ваши программные 
инструменты $81. не выполняют все эти действия за вас, лучше 
оставить столбцы на старом месте. Вы всегда можете получить 
столбцы командой ЗЕТЕСТ в любом нужном порядке. 


: Получается, легко изменить порядок следования столб- 
цов можно только при добавлении нового столбца? 


() Правильно. Лучше всего заранее продумать порядок столб- 
цов в ходе проектирования таблицы. 


|- 


У 


= Команда СНАМСЕ позволяет изменить как 
имя, так и тип данных столбца. 


КЛЮЧЕВЫЕ 
МОМЕНТЫ 


= Команда мортғү используется для измене- 
ния только типа данных. 


= Команда ркор согом удаляет столбец 
с заданным именем из таблицы. 


Команда ВЕМАМЕ изменяет имя таблицы. 
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Сы 


* Аесли я случайно создам первичный ключ, а затем 
передумаю и захочу использовать другой столбец? Можно 
ли удалить атрибут первичного ключа без изменения дан- 
ных, хранящихся в столбце? 


(} Можно, притом очень просто: 


АГТЕК ТАВІЕ уоџг ёар1е КОР РВТМАВУ КЕҮ; 


| Как насчет атрибута АОТО ІМСКЕМЕМТ? 


(} Его можно назначить столбцу, у которого этого атрибута нет, 
следующим образом: 


АГТЕВ ТАВІЕ уоџг ќар1іе СНАМСЕ уоџг іа уоџг іа 
ІМТ (11) №Т МОБЪ АОТО ТМСВЕМЕМТ; 


А удаление выполняется следующим образом: 


АГТЕВ ТАВІЕ уоџг ёар1е СНАМСЕ уоџг іа уоцг іа 
ІМТ (11) №Т №; 


Помните, что в таблице может быть только одно поле АОТО_ 
ІМСАЕМЕМТ, оно должно относиться к типу данных ТМТЕСЕВ 
и не может содержать №01. 


= Для определения порядка столбцов ис- 
пользуются ключевые слова ЕТВЗТ, ІА5Т, 
ВЕРОВЕ имя столбца, АЕТЕК имя столбца, 
ЅЕСОМР, ТНТВО, РООВТН ИТ. Д. 


= В некоторых РСУБД порядок столбцов 
может изменяться только при добавлении 
их в таблицу. 


АІТЕВ 


Теперь в моей табли- 
це есть первичный ключ и столбец 
с номером телефона, но с атомарностью 
по-прежнему проблемы. Некоторые запросы 

остаются слишком сложными — как, на- 
пример, запрос по названию штата в поле 
Іосаїіоп. 


Команда АЕТЕК ТАВІЕ помогает улучшить 
структуру таблицы. 


Используя АГТЕВ ТАВІЕ вместе с командами 
ЗЕТЕСТ и ОР”РАТЕ, мы можем преобразовать гро- 
моздкие, неатомарные столбцы в точные и удоб- 
ные атомарные столбцы. Для этого нужно лишь 
правильно скомбинировать уже известные вам 
команды 801. 


Рассмотрим команду СВЕАТЕ ТАВІЕ для таблицы 
Грега ту сопбасізѕ. 


СВЕАТЕ ТАВІЕ ту сопёбасіѕ 


( 


Зили две 
Силроки созда. 
ил ц назна - 
чаюил иервцц - 
ный Ключ. 


№ 


сопёасі іа ІМТ МОТ МОШ. АОТО_ТМСВЕМЕМТ 

Іаѕє пате УАКБСНАБВ (30) деҒаоџ1+ МО, 

Е1г5е пате УАВСНАВ (20) деҒаџіє МОТ, 

ема11 УАВБСНАК (50) деҒаџі+ МО, 

деп4ег СНАК (1) ЯаеҒаџ1іє МЈ, 

ЬігіҺаау РАТЕ еҒаџі МОШ, 

ргоҒеѕѕіоп УАВСНАВ (50) ЯеҒаџ1+є МОІІ,, ИА 
Іосаііоп УАВБСНАК (50) деҒацџі+ МЛІ, «~_ не амомарно 
ѕбаёцѕ УАВСНАК (20) деҒ#ац1+ МО, и НЫ 
іпёегеѕіѕ УАВСНАБВ (100) деҒаџіє МОТШ,, г АІТЕК ТАВЬЕ. 
ѕеекіпд УАКСНАБВ (100) деҒаџі+ МОТ, =— 

РВТМАКУ КЕУ (сопёбасї іа) 
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разбиение занных 


Неатомарный столбец [оса оп 


Иногда Грег хочет узнать лишь то, в каком штате или городе живет 
его знакомый, поэтому информацию 1осабіоп логично разбить 
на два столбца. Давайте посмотрим, как выглядят данные в этом 
столбце: 
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Ее Бай Умпдом Нер ГосайопосайопГосавот 


ГЕ1е Еа МИпдом Нер Госанопсосаволсосаот а) 
--> ЗЕБЕСТ Іосаііоп РВОМ му сопѓасёѕ; 


+ 


+ 


1осаЕ1оп | 


+ 


Сиэтл, МА 


Натчез, М5 


Лас Вегас, МУ 
Пало Альто, СА 
Нью-Йорк, 


с, 


Часиль данных 
силолдиа <[осаН ол» 


иладлицы Сиэтл, МА <—^ двихбиквенное 


илЧ_соифасЕб. 


гпава 5 


Натчез, МЅ < сокраиленчё иилаила. 
ГА 


Лас-Вегас, МУ 
Ван ЕЕ ЕЕ ‚ СА 
города. < Нью-Иорк, МУ 
Замяилӣя. 
Данные построены по четко определенной схеме: 
сначала идет название города, потом запятая, 


а за ней двухбуквенное сокращение штата. 
Это поможет нам отделить город от штата. 


с мозговой 
ШТУРМ 


Какую пользу принесет отделение города 
от штата? 


Как вы думаете, что мы будем делать дальше? 


АІТЕР 


В поисках закономерности 


Все значения столбца 1 осаїіоп в таблице ту сопіасіѕ построены 
по одной схеме: название города, запятая и двухбуквенное сокраще- 

ние штата. Наличие четко определенного формата упростит разбие- 
ние и переход к атомарным данным. 


вола всегда содержа 


едние два сим мых 
Ф ИЯ ценное обозначение милаи^ т 
Б? Е р илсилвовал си^ 
бы 6 илаблице ирис9 оа 
И сае, эили данные должне! 
Запяилая, коилорая Всегда силоиил н иилося И 


перед сокращенным обозначением 
иилата, иложе можеил иригодиилься... 


Сначала выделяем все данные до запятой Затем берем два последних символа столбца 
и переносим их в столбец с названием города. 1 осасіоп и переносим их в столбец зїаѓе. 


С1Еу Мате ХХ 
а қ 


Нам понадобится функция, и еще одна ф 

Ункиия, коило- 
коилорая возвраидаеил все рая возвра 
и. о АРха Ая щаетл два последних 
«Возьми в руку карандаш 


чы, Напишите команду АІТЕК ТАВІЕ, которая добавляет 
ь“ в таблицу ту сопсасіѕ столбцы сі+уи эфаке. 


(=)ыуУНа 22035 мипло2 аат 


‘(о$)ыУн2ыУл 
632 миплор аау 


52203м02 Бум 3191 У211У 
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строковые функции 


Удобные строкоВые функции 


Мы обнаружили две закономерности в формате данных. На 


следующем шаге мы выделим сокращенное обозначение штата Текстовые значения, 
и вставим его в новый столбец з$афе. Все символы, стоящие 
до запятой, необходимо перенести в столбец с1 У. Вот как бу- хранимые В ето лбцах 


дет происходить выделение данных после того, как в таблице 


будут созданы новые столбцы. СНАВ И УАВСНАВ 
) 
Выборка двух последних символов тоже называютея 


Для выделения заданного количества символов в столбце использу- 


ются функции КІСНТ () иІЕЕТ (): строками. 


ЅЕ1ЕСТ с лов, 2) ЕВОМ ту сопёасіѕ; 
а: 26 


р \ 
Выделение символов 


7 Количесилво символов, 
оил ПРАВОГО края 


Исиользцемыи д 
В быделяемых оил правого 


значения (функиия О, края значения. 

ГЕРТ выделяеил сим- 

боле! оил левого края) Строковые функции 
Выборка Всех симВолов до запятой выделяют часть 
Функция 50В5ТКІМС ІМРЕХ () находит все символы тексто- значения текетового 
вого значения, предшествующие заданному символу или 
подстроке. Запятая заключается в апострофы, а функция столбца. 


ЗОВЗТВ1МС _ТМОЕХ () возвращает все символы, стоящие 
перед запятой. 


ЗЕЪЕСТ ЗОВЗТАТМС ТМОЕХ (1осабіоп, ',', 1) ЕВОМ ту сопіасізѕ; 


Иры сенуге. і) 7 6 
/ 
РЕ И снова имя Замяилая, «1», поилому чило ищеился 


силолдбиа. коилорая первая заляилая. С параме- 


Функция Выделяеил часиль со- ишеился миром <«2> функция найдеил 
держимого силолбиа (подсилрокц). 6 илексиме. Вилорую заляилую в силроке 
Она ищеил илексил, заключенный 


и Вернеил все иредщесилвиую - 


6 и (запяилая в данном щие ей символы. 


случае), и возвращаеил все симво - 
лы, предщесилвующие емц. 
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АІТЕВ 


Попробуатеїсами 


\ В 501 существует ряд функций для работы со строковыми значениями в таблицах. 
пражнение Строковые значения хранятся в текстовых столбцах, обычно с типом данных УАВСНАВ 
ИЛИ СНАВ. 


Ниже перечислены наиболее распространенные и полезные строковые функции. 
Опробуйте каждую функцию, введя соответствующую команду 5ЕІЕСТ. 


Функция ЗОВЗТАТМС (текст, начало, длина) возвращает часть строкового значения текст, начиная 
с буквы в позиции начало. Параметр длина определяет длину возвращаемой строки. 


ЅЕІЕСТ 80В8ТКІМС ('Сан-Антонио, ТХ', 5, 3); 


Функции ОРРЕВ (текст) и ІОИЕВ (текст) преобразуют все символы строки к верхнему или нижнему 
регистру соответственно. 


ЅЕЕСТ ОРРЕК ('сШа'); 
ЅЕІЕСТ ГОИЕВ ('спаГЕтти!); 

Функция ВЕУЕВЗЕ (текст) переставляет символы строки в обратном порядке. 
ЅЕІЕСТ ҚКЕҮЕКЅЕ ('спаГЕтти'); 


Функции ГТВТМ (текст) и АТВІМ (текст) возвращают строку, полученную удалением лишних пробе- 
лов в начале (у левого края) или в конце (у правого края) строки. 


ЅЕТЕСТ ЪТВ1М(' собака '); 
ЅЕІЕСТ ЕТКІМ (' кошка '); 
Функция ІЕМСТН (текст) возвращает количество символов в строке. 


ЅЕ1ЕСТ ТЕМСТН ('Сан-Антонио, ТХ '); 


ВАЖНО: Строковые функции НЕ изменяют данные, хранящиеся в таблице; 


они просто возвращают текст, сгенерированный в результате запроса. 
——=—щЩщЩщШЩШЫ—Ды—аПД—Да—а—щ —Ш—ш=ыы—Ы—=—=—=ы=ы>»>»>—»—=—= 
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кто и что Запает7 


+ 
кто и «Селф 


Мы хотим извлечь данные из столбца 1 осаїіоп и переме- 
стить ее в два новых столбца, сіёуи зёаѓе. 


Ниже перечислены операции, которые необходимо для этого 
выполнить. Свяжите операции с ключевыми словами 501, 
которые в них используются. 


ЕХ 
ЅОВЅТВІМС ІМОЕХ () 578 


1. Просмотреть данные столбца, чтобы найти 
в них закономерность. 


АБО СОШЈММ 


2. Добавить в таблицу пустые столбцы. 


КІСНТ 


3. Извлечь часть данных из текстового столбца. 


АГТЕВ ТАВТЕ 


4. Переместить данные, полученные на шаге 3, 
в один из пустых столбцов. 


ОЕГЕТЕ 


4 (заветы: на с, 262. 
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АІТЕВ 


Я знаю, как использовать каждую из частей, но 
еще не умею эффективно объединять их друг с дру- 
гом. Может, попробовать включить эти строковые 
функции в команду ЧРОАТЕ. . 


Если пользоваться только тем, что 
мы узнали до настоящего времени, 
нам придется написать команду 
УРОАТЕ для последовательной 
обработки отдельных записей, 

с получением нужных данных 
командой ЗЕЁЕСТ. 

СОГ вы сможете комбинировать команды. 
Переверните страницу, чтобы посмотреть 
как поместить значения в новые столбцы. 
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кто и что долаег: ? 


+ З 
+кто и Ко ЕАК 


Мы хотим извлечь данные из столбца 1осаёіоп и переме- 
стить их в два новых столбца, сіу и ѕёаѓе. 


Ниже перечислены операции, которые необходимо для этого 
выполнить. Свяжите операции с ключевыми словами 501, 
которые в них используются. 


Ѕ0ВЅТВІМС ТМОЕХ () 


А ет 


1. Просмотреть данные столбца, чтобы найти 
в них закономерность. 


ТЕЕТ 
АБР СОБОММ 


2. Добавить в таблицу пустые столбцы. 


\ АРЈОЅТ 
КІСНТ 
“а > Извлечь часть данных из текстового столбца. 
| 
АТТЕВ ТАВІЕ 
РЕТЕТЕ 4. Переместить данные, полученные на шаге 3, 


в один из пустых столбцов. 


7 


| МЅЕРТ 
ОРРАТЕ Р 
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АІТЕВ 


Заполнение нового столбца существующими данными 


Помните синтаксис ОРРАТЕ? Ранее мы использовали его для заполнения всех 
записей таблицы одним и тем же значением. Параметр новое значение заме- 
няется значением или именем другого столбца. 


ОРРАТЕ +ар1е паше р Команда заполняеил силолбец 


заданным значением Во Всех 


за СЯ, я 
ЗЕТ столбец = новое значение; писях иладлицы 


Чтобы заполнить данными новые столбцы сіїуи ѕѓіаѓе, 
МЫ ВКЛЮЧИМ ВЫЗОВ функции КІСНТ () в команду ОРРАТЕ. 
Функция выделяет два последних символа из старого 
столбца 1 оса іоп и помещает их в новый столбец ѕіаќёе. 


ОРРАТЕ шу сопфасе$ 


ЗЕТ збафе = ВТСНТ (1осаёіоп, 2); 
‚Я у. аи 


Новый силолбе К, вызов функии 

ц для ЭЗилои^ д- 

сокращенного обо- быделяеу два после 
ла 


значения идилаила. 


[осаНои: 


Но как работает эта 
команда? В ней нет условия 
МНЕВЕ, определяющего об- 
новляемые записи. 


Команда работает без условия 
УУНЕКЕ. Переверните страницу 
и посмотрите. 
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объединение команд 54! 


Как работает Комбинация ЏРОАТЕ с $ЕТ 


Ваша РСУБД последовательно применяет команду к каждой 
записи таблицы до тех пор, пока все сокращенные обозначения 
штатов не будут перенесены в новый столбец эф асе. 


пу сопёасізѕ 


Честер, № Упрощенная версия 
лей млаблици. 
Сан-Матео, СА 


ОРРАТЕ пу сопіасіѕ К Команда 501. 
ЅЕТ зфафе = ВТСНТ (1осаііоп, 2); 


Строковые функции 


Давайте посмотрим, как работает этот процесс, на приме- 


ре упрощенной таблицы. Сначала команда берет значение могут использоваться 


1осабіоп из первой записи и обрабатывает его. 


Затем команда начинает перебор сначала, находит значение В командах УЕТЕСТ, 
1осабіоп во второй строке, обрабатывает его — и так далее, рр АТЕ и ПЕГЕТЕ 


пока столбец не будет разбит во всех записях, а в таблице не 
останется записей, которые еще не были обработаны. 


оз 
Первая Пе УРВАТЕ ту_сог{ас{$ команда обрабаичева - 
иилерация. ЗЕТ ѕќаќе = К СНТ('Честер, №.",2) сил силолбец <осаной» 
первой записи. 
Вилорая А. | 
ера УРБАТЕ ту _сопќасѓѕ Е вилорой залиси. 
ЗЕТ з{ае = КІСНТ("Кейти, ТХ',2) 
Итерация с 
илретья ОРОАТЕ ту_соп{ас{$ е наконец, для илреильей. 
и последняя ЅЕТ ѕќаќе = КІСНТ('Сан-Матео, СА',2) 
(6 иладлиие 
всего илри 
записи). 
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АЕТЕЮ 


Возьми в руку карандаш 
| \ ешение Изобразите структуру таблицы после выполнения команды на с. 244. 
= Со с. 210. 


ргојесё 115% 


фезетрНопо#рго] 


/ 


Силолбец 
<<‹пиилбеи> превра- 
илился 6 <«рио]-14>; 
6 нем храняился 
авиломаилически 
чвеличиваемые 
значения иервич- 
ного ключа. 


ТТ 

ЕНЕНЕ ГЕНА 
а амана ване 
заемы аә 
а Гевин | анын 
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краткий обзор $4! 


ГЛАВА 5 


266 


Новые инструменты 


Поздравляем — глава 5 осталась позади, 
а в вашем арсенале появилась команда 
АІТЕК. Полный список инструментов 
приведен в приложении 11. 


АТТЕВ ТАВІЕ 
Команда позволяем и3- 
менииль имя млаблица, 
и всю ее си^рукилЧРУ 2 
помери су\щеси“ уюшщ 
данных. 


АТЕВ с Арр 


Добавление силолбиов 
6 илаблииу в заданном 
порядке. 


АПТЕВ с ОВОР 


Удаление силолдиов из 
илаблииы. 


Строковые фун 


Функции, изменяющие 
Копии содержимого илек- 
силовых Силолдцов, Воз 
Ращаемые запросом 
сходные данные осила— 
ЮюЮился неизменными. 
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6 Гасширенные ВозЗМоЖ Ностри «ІСТ 


№ 
+ Взглянуть на данные 
под другим углом * 


Тогда я использую 
САЅЕ — и вижу вражеские 
самолеты как на ладони! 
Бабах! 


Пора обзавестись более точными инструментами. 
Вы уже знаете, как выполнять выборку данных, и умеете работать 


с условиями ИНЕКЕ. Но в некоторых ситуациях нужна точность, 

на которую 5ЕЪЕСТ и ИНЕКЕ не способны. В этой главе вы научитесь 
упорядочивать и группировать свои данные, а также выполнять 
математические операции с полученными результатами. 


упорядочиваем существующие данные 


Перестройка В ВидеотеКке 


В видеотеке городка Дейтавиль дело орга- 
низовано из рук вон плохо. Фильмы могут 
оказаться на разных полках в зависимости от 
того, кто из работников занимается их рас- 
становкой. Владелец заказал новые полки, 


и он думает, что пришло время распределить 
фильмы по категориям. 


ратат 
Мрео 


ЕК ВААЗАКА И 
== 4 я 1 


То: Персоналу видеотеки 
В иректор СЯ 
ох ыы полкам — новые категор 


Всем привет, 
ивести 

Новые полки уже привезли, и я ыы неве 

в порядок наши фильмы. Мы буде 

вать следующие категории: 


Боевики и прикпючения 
Драма 
Комедия 
Семейное кино 
Ужасы 
Фантастика и Фэнтези 
Разное 


= 


—- 


% 
А 
1. 

4 баор сатаа 


ю 
Разберитесь сами как заставить нашу текущу 

и ми. 
таблицу работать с новыми категория 


А мне пора на обед. 
В текущей версии системы типы фильмов обозна- 


чаются флагами «да/нет», из-за чего классифика- 
ция становится весьма затруднительной. Напри- 
мер, на какую полку ставить фильм, у которого 


установлены флаги категорий «Комедия» и «Фан- 
тастика»? 


Директор 


«Д» и «Н» — сокращения 
для «Да» и «Немл. 


Даила приодреиления 
фильма. 
< поуіе баЬ1е 


Грета 


Корпорация монстров Є Е 
5-2-2001 
Е Е 


Е 
База 
[Г коетныйоты [в 
[Унесенные ветром |6 
[Американскийлиро | 
[кошмар на улице вкз В 


5-2-2001 


Все эили силолбиы счщесилвуюил для илого, чилобы 
рабоилники могли оплвечаиль на вопросы о содер- 
жании конкреилных фильмов. 
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расширение возможности ЗЕЁЕСТ 


Недостатки существующей таблицы 


Ниже перечислены основные недостатки существующей таблицы. 


' Когда посетители возвращают фильмы, 
: мы не знаем, Куда их ставить. 


: Если флаг «Д» стоит в нескольких столбцах таблицы, невоз- 
: можно четко определить, на какой полке должен стоять фильм. 
: Каждый фильм должен относиться к одной категории. 


: Посетителям непонятно, К Какому Жанру относится 
: фильм. 


: Посетителей сбивают с толку кровавые обложки в разделе 
: «Комедия». В текущей версии все флаги «Д/Н» равноправны 
: при размещении фильмов на полках. 


зоне ии оное вовне та ов оу узо онова о нон ое па новава ватна но оавана оваа о танаа вне ь п ан ев рава о позе во 


ОРСИНИ Е ИАА И ИИААЩЕ О ТЕГ ТИР ИДИТЕ ИИ 


‚ Правка данных занимает много Времени 
: и часто приводит К ошибкам. 


: Каждый раз, когда в видеотеке появляется новый фильм, его 

: необходимо занести в базу, и расставить все флаги «Д/Н». 

: И чем больше фильмов хранится в таблице, тем больше оши- 

: бок. Иногда в столбце, в котором должен стоять флаг «Д», слу- 
: чайно ставится «Н», и наоборот. Столбец с категорией фильма 
поможет проверить содержимое столбцов «Д/Н» — а со време- 
: нем и вовсе избавиться от них. 


ААО ОЗА вова чо Э А00 = 


Новый столбец с информацией о категории ускорит расстановку, 
поможет посетителям понять, к какому жанру относится интересу- 
ющий их фильм, а также сократит количество ошибок в данных. 


ос мозговой 
ХООШТУРМ 


Как бы вы преобразовали текущий набор столбцов в новые категории? 
Возможна ли в новой классификации ситуация, когда один фильм при- 


надлежит сразу к нескольким категориям? 
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обработка существующих данных 


Классификация существующих данных 


Вы уже знаете, как добавить в таблицу новый столбец саїедогу, 
но сего заполнением дело обстоит сложнее. К счастью, категорию 
каждого фильма можно определить по данным, уже хранящимся 
в таблице, и нам не придется просматривать все фильмы подряд. 


Если 'Д' в столбце: в столбец саїедогу заносится 


в столбец саїедогу заносится 


Если 'Д' в столбце: 


Если 'Д'в столбце: 


евр Е 


в столбец саїедогу заносится ' 


Если 'Д' в столбце: боғ К в столбец саїедогу заносится ‘с 
Если 'Д’в столбце: сағћооп и 'бв столбце": | га ту і в столбец саједогу заносится ‘семейное! 


Если '‘Д' в столбце: 


и НЕ 'С'в столбце: в столбец саїедогу заносится ‘разное 


слых. Силолбец 
оил и для ёзро н 
илфилеме! быва нисе 
ае, оилносиился филем К Ра Ри суми 
ой Если фильму присвоен рейии рН ни. 
Е меННОе», а если нем — К ка 

ри 


0. 


«уакта» поможем 
ного кино или 
м его к каилёего- 
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\ 


Давайте сформулируем отношение в виде набора простых условий: 
Если 'Д' в столбце: в столбец саїедогу заносится оне 
26 
г 
Если `Д'в столбце: в столбец сатедогу заносится ‘ком, 


расширение возможности ЗЕЁЕСТ 


Заполнение ноВо2о столбца 


Теперь эти условия преобразуются 


в команды 501. ОРРАТЕ: 


_—>> ЧРОАТЕ тоуіе бар1е 
_> ОРРАТЕ шоу1е фаБ1е 
эу ЧРОАТЕ поуіе бар1е 
257 ОРРАТЕ шоуіе бар1е 
[А > ОРБАТЕ шоуіе баБі1е 
27 ОРРАТЕ шоуіе +ађ1іе 
ОРРАТЕ поује ёар1е 
А ОРРАТЕ шоу1е баБ1е 


< 


Большое приключение 


Грег: Неизвестные 
истории 
Безумные клоуны 


Параскеведекатриа- 
фобия 


с 


Планета пригодна 
для жизни 


ЅЕТ 
ЗЕТ 
ЗЕТ 
ЗЕТ 
ЗЕТ 
ЗЕТ 
ЗЕТ 
ЗЕТ 


Возьми в руку карандаш 


= 
РС 
РИ 
5 
а 
8 


сафедогу 
сафедогу 
сафедогу 
сабедогу 
саіедогу 
сафедогу 
сафедогу 
сабедогу 


Н 
Н 
Н 


Н 


= 'драма' мћһеге гата = 'Д'; 

= 'комедия' мһеге сошеду = 'Д'; 

= 'боевик' ућһеге асбіоп = 'Д'; 

= ‘ужасы! мһеге доге = 'Д'; 

= 'фантастика' ићһеге зс1#1 = 'Д'; 

= 'семейное' ивеге ог К14$ = 'Д'; 

= 'семейное' иһеге сагіооп = 'Д' АМО гаёіпд = 'С'; 


= 'разное' эһеге сагіооп = 'Д' АМР гаїіпд <> 'С̧'; 


А 


Рейилинг билличен оил ‘с? 


Заполните столбец саседоку для следующих фильмов: 
шоу1е фаБ]е 
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возьми в руку карандаш. решение 


«. Возьми в руку карандаш 
< Решение 


Заполните столбец сасесдогу для следующих фильмов: 


9 
шоуіе фаБ1е 


Большое приключение 


Н боевик 


| 


н 
семейное 
н 
н 


р 
Планета пригодна РС т Е 
для жизни 
Вопросиилельным знаком помечены силолдцы, изме - р 


ненные более чем одной командой ОРРАТЕ. Значение 
силолдиа зависиил оил порядка выполнения ОРРАТЕ. 


Н 


Е 


Н 
Н 


Е З 
ЕЕ 
ЕЕ 


Зависит ли результат от порядка проверки столбцов Д/Н? 


Порядок Важен Результат зависит от порядка 
Например, если столбцы будут пере- 

бираться авас. фильм проверки. 
«Параскеведекатриафобия» попадет 

в категорию фантастики, хотя умест- Две команды ОРРАТЕ могут 
нее было бы отнести его к комедиям. 

Если мы не знаем, к какой категории изменять содержимое ОДНоОГ 0 
относится тот или иной фильм, воз- „ 

можно, лучше зачислить его в катего- етолоца. 


рию «Разное». 


272 глава 6 


расширение возможности ЗЕЁБЕСТ 


Для маленькой таблицы этот 
способ подойдет, а если таблица содержит 

сотни столбцов? Можно ли как-то объединить 
все эти команды ОРРАТЕ в одну большую 


Да, можно написать одну большую команду 
ОРРАТЕ, но есть и более удобный способ. 
Выражение САЅЕ объединяет множество команд 
ОРРАТЕ, проверяя значение существующего столбца 
по условию. Если условие выполняется, то новый 
столбец заполняется заданным значением. 


Вы даже сможете указать РСУБД, что делать с запи- 
сями, не удовлетворяющими ни одному условию. 


Эилому силолбич 
ОРОАТЕ ту +ар1е / присваивается одно 
Е из перечисленных 

ЗЕТ новый столбец = ниже значений. 

Начало вВыраже- 24 

ния САЅЕ. Аа. Е 
ЕСЛИ выполняется 
и >ИНЕМ столбец1 = значение1 


силолбич «новый_ Оилсил 
ем» присваивает ТНЕМ новое _ значение1 не ее. 
вился ЭТО значение. на обрабоилкц 
ЕЕ __22. МНЕМ со1їџштп2 = значение2 выражения; 
а А6 быполняет= они всего лишь 
Ругое условие. ТНЕМ новое значение? уирощаюил 
ТО силолбич Бе чиление кода. 
«новый. силолбец»» ЕІЅЕ значение3 
присваиваеился 


рии С ' м Если ни одно из условий 
не вылолняеился, и^о силол 
Завершаеил Выражение м сеолбец» при- 
ОРРАТЕ (3 аса ваиваеился ЭТО значение. 
ОРРАТЕ (завершающий с 
симбол <;»). 
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УРБАТЕ с САЅЕ 


ОРОАТЕ с выражением САЅЕ 


Давайте посмотрим, как выражение САЗЕ работает 
с таблицей тоуіе сар1е. 
То же самое, Чило ОРРАТЕ 


ОРОАТЕ поуіе фаЪ1е миломе Бабе ЅЕТ саѓедогӯ = 
ЅЕТ сафедоку = г ‘драма’ МНЕВЕ ағама = 


| 

САЗЕ ‘'Д;— но намного комиакилнее: 

ИНЕМ агата = 'Д' ТНЕМ 'драма' 

ИНЕМ сотейу = 'Д' ТНЕМ 'комедия' 

ИНЕМ асёіоп = 'Д' ТНЕМ 'боевик' 

ИНЕМ доге = 'Д' ТНЕМ 'ужасы' 

ИНЕМ ѕсіҒі = 'Д' ТНЕМ 'фантастика' 

МНЕМ Еог Кіаѕ = 'Д' ТНЕМ 'семейное' 

ИНЕМ сагіооп = 'Д' ТНЕМ 'семейное' 


' ' 
ЕІ5Е 'разное Значения, коилорые осилавались не- 


ЕМО; | определенными ири заполнении ново- 
дходящим ни по го силолбиа оплдельными командами 


ем залисям, не по М я. (РГ 
Всем словий, назнача ЧУРРАТЕ, илеиерь определены. 


одно из перечисленных У 
>>, 
сился камлегория «разное и о 


новые значения для фильмов <«Разгне- 


ванный лираил» и «Конец очереди». 
шоуіе +ар1іе " 


Гана Ганин Гане Ге реет аин | 

сатти С МОИ ОИ О СИ СЕ ССИ ИСИ 

ПО ОСИ ОСИ ОСИ ОС Е ОС ОС ОСИ 8 
Д Д Н Д Н Н 


Параскеведекатриафобия В Д драма 


Д 


Блестящие вещи РС 
2 


аберите обратно 


Наживка для акул семейное 


ата Раа ра ИИ 

Н Н Н Д Н 
Разгневанный пират РС Н Н Н Н Д комедия 
Н 


Н Г Н Н комедия 


Планета пригодна для жизни РС 
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расишрение возможности ЗЕЁЕСТ 


В процессе обработки значений «Д/Н» каждого фильма выражением САЗЕ 
РСУБД ищет первый столбец с «Д», чтобы установить по нему категорию. 


Давайте посмотрим, как происходит обработка данных фильма «Большое при- 
ключение»: 


ОРРАТЕ тоуіе ЕаБ1е ори 
5 НЕТ: каилёё 
ЗЕТ. баведову лока неизвесиНЯ НЕТ: каилегория 
САЗЕ = лока неизвесилна 
ИНЕМ Агата = 'Д' ТНЕМ 'драма' ла 


НЕТ: категория 
ИНЕМ соме4ду = 'Д' ТНЕМ 'комедия' 


мока неизвесилна 


ИНЕМ асііоп = 'Д' ТНЕМ 'боевик' НЕТ: каилегория 
МНЕМ доге = 'Д' ТНЕМ 'ужасы' < пока неизвесилна 
ИНЕМ $с1Е1 = 'Д' ТНЕМ ' фантастика‘ ЕГ категория 
МНЕМ Ғог Ккіаѕ = 'Д' ТНЕМ 'семейное' 
МНЕМ сагіооп = 'Д' ТНЕМ енен УИ 
ЕІ,5Е 'разное' 

ЕКО: Р ДА: 6 силолбец 


<«сафедоиц> заносиился 
значение ‘семеиное, 
управление переда - 
еился ЕМО, вВыполне- 
ние команды завер - 


Вот что происходит при обработке записи фильма «Параскеведекатриа- — шаеился. 
фобия»: 


ОРРАТЕ тоуіе +ар1е 


ЅЕТ сафедогу = ДА: фильму назна- 
САЗЕ чаеился каилегория 


ИНЕМ Агата = 'Д' ТНЕМ 'драма' < «драма»; управление 
др 


Теперь рассмотрим запись с совпадениями в нескольких категориях. Как 


и в предыдущем случае, категория фильма определяется первым найден- 
ным столбцом, содержащим «Д». 


= 'п! ' ' передаеился ЕМР, вы- 
ИНЕМ сотеду Кая ТНЕМ ‘комедия полнение кода завер. 
ИНЕМ асііоп = 'Д' ТНЕМ 'боевик идаеился. Осилальные 
ИНЕМ доге = 'Д' ТНЕМ 'ужасы' значения Д. игнорирц - 
ИНЕМ ѕсіҒі = 'Д' ТНЕМ 'фантастика' '°”* 


МИНЕМ Ғог Кіаѕ = 'Д' ТНЕМ 'семейное' 
ИНЕМ сагіооп = 'Д' ТНЕМ 'семейное' 
ЕІ5Е 'разное' 

ЕМО; 
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проблемы с САЗЕ 


Похоже, у нас проблемы 


Произошло нечто непредвиденное. 


му тф ь дл З а ы 
ль ильм яв рослых аким-то об азо оп. в катего 
й к р зом п ал рию 


«Большое приключение» — 


Сообщение 
Дата Сегодня Тіте 15.41 


соп, Вон» во Зо ОА РЬ ао олс Со о ао Заа Оаа вол 


Звонил “Просил перезвонить | \“ 


Хотел говорить с вами ча Будет звонить снова 


Хочет встретиться 
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расширение возможности ЅЕГЕСТ 


«Возьми в руку карандаш 


Измените выражение САЅЕ так, чтобы мультфильмы (столбец 
є. сагќооп) попадали в категорию ‘разное, а не ‘семейное! Только 
если мультфильму присвоен рейтинг С, он помещается в катего- 

рию семейного кино. 


Со мозговой 
ШТУРМ 


Как использовать рейтинг К, чтобы подоб- 
ные инциденты не происходили в буду- 


щем? 


дальше › 277 


возьми в руку карандаш. решение 


Возьми в руку карандаш 
Ч Решение 


ъ. 


Измените выражение САЗЕ так, чтобы мультфильмы (столбец 
сагіооп) попадали в категорию ‘разное’ а не 'семейное’". 
Только если мультфильму присвоен рейтинг С, он помещается 
в категорию семейного кино. 


ОРРАТЕ иломе_а Ме 
ЅЕТ саедогц = 
САЅЕ 

МИНЕМ 4кгаила = ‘Д’ ТНЕМ ‘драма! 

МНЕМ сомедц = "Д' ТНЕМ ‘комедия’ 

МНЕМ асои = ‘'Д’ТНЕМ ‘боевик! 

М/НЕМ доғе = ‘Д! ТНЕМ ‘ужасы 

М/НЕМ сі! = Д’ ТНЕМ ‘фаниласилика' 

М/НЕМ Рок Кій = 'Д’ТНЕМ ‘семейное’ 

М/НЕМ сагфоом = ‘Д’ АМР” ганид = 'а' ТНЕМ семеиное’ 

ЕЁЗЕ 'иліѕс' 
ЕМО; Условие можеил сосилоятль из нескольких часилей: еЗ 
чевое слово АМР ироверяеил, чило зило м лвилф ь А 2 
И он имееил рейилинг С! Если сос > ха 


силавное сословие Вы 
лол и 
няеился, фильму назначаеулся каилегория ‘семейное’ 


частро 


№ 
ы—ШЫШЫ о уАаваеМые —————-————------—— —— 


Воть Сы 


0: Обязательно ли использовать ЕІ5Е? 


() Нет, не обязательно. Не включайте это условие, если оно 
не требуется, но обычно бывает удобно предусмотреть способ 
обновления столбца, если ни одно условие не выполняется. 

В такой ситуации лучше заполнять столбец каким-то значени- 
ем, отличным от М№ОТІ.. 


В: Что произойдет, если ни одно из условий ИНЕМ 
не подходит, а ЕЕ отсутствует? 


. > 
() Обновляемый столбец не изменяется. 
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а если я хочу использовать выражение САЅЕ толь- 
ко для некоторых значений столбцов? Например, если 
выражение САЗЕ должно применяться только в случае 
сафедогу = 'разное'. Могу ли я использовать ИНЕВЕ? 


() Да, после ключевого слова ЕМР можно добавить условие 
ИНЕКЕ. Выражение САЅЕ будет применяться только при вы- 
полнении условии НЕБЕ. 


Можно ли использовать выражение САЅЕ с другими 
командами, кроме ОР”АТЕ? 


() Да. Выражение САЗЕ может использоваться с командами 
ЗЕЪЕСТ, ІМЅЕРТ, РЕЪЕТЕ — и, как вы уже видели, ОРРАТЕ. 


расинрение возможности ЗЕЁЕСТ 


= =: — и И 


КОМАНДЫ С САЅЕ 


оналу видеотеки 
То: Перс У 


А Директор 
Е Новые категории 


Беспокойному директору видеотеки пришла в голову 
очередная «гениальная идея». Прочтите его сообщение 


и напишите одну команду 501, которая делает то, что ему 
нужно. 


Дорогие коллеги! 


Я решил создать несколько возера 
Мне кажется, что фильмы с ратно 
должны находиться на полках а тз 
от фильмов с рейтингами си 1 

создадим 5 НОВЫХ категорий: 


ужасы-г 
боевик-г 
драма-г 
комедия-г 
фантастика-т 


} мы 
А если в категории 'разное' есть мария ей 
с рейтингом С, давайте перенесем 


рию семейного кино. 


Всем спасибо, 
Директор 


трудно найти нужный фильм. Напишите команду, которая 
удаляет только что созданные категории с рейтингом В. 


Наконец, удалите столбцы Д/Н, которые нам больше не нужны. 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| Оказывается, с новыми категориями посетителям стало 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
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решение задачи с саѕе 


"=. => => ==> = —. = 


КОМАНДЫ С САЅЕ 


Беспокойному директору видеотеки пришла в голову 
очередная «гениальная идея». Прочтите его сообщение 
и напишите одну команду $О1, которая делает то, 
что ему нужно. 
ОРРАТЕ иломева Ме 
ЅЕТ саїедоүч = 
САЅЕ 
ҮНЕМ агаила = 'Д’АМР кайид = ‘Ё ТНЕМ ‘драма - 


\М/НЕМ сорледу = ‘Д’ АМР” гайид = ‘Ё? ТНЕМ ‘комедия -г' 


УНЕМ асїіои = Д’ АМР гайид = 'В' ТНЕМ ‘доевик-г 
М/НЕМ доғе = ‘Д’АМР гайд = ‘В’ ТНЕМ ‘ужасы-" 


М/НЕМ сЁ! = "Д' АМР” каба = ‘В’ ТНЕМ ‘фаниласилика-г 
М/НЕМ саёедогц = ‘разное’ АМР” гаНид = '(’ТНЕМ ‘семейное’ 


Персоналу видеотеки 


То: 
Н Директор 
сЕ Новые категории 


Дорогие коллеги! 
несколько новых разделов. 
фильмы с рейтингом К 


я на полках отдельно 
С. Давайте 


Я решил создать 
Мне кажется, что 
ходитьс 
должны на » 
от фильмов с рейтингами ои Р 
создадим 5 новых категорий: 


ужасы-г 
боевик-г 
драма-г 
комедия-г 
фантастика-г 


‘разное' есть фильмы 


А если в категории есем их в катего- 


с рейтингом С. давайте перен 


Е рию семейного кино. 


Всем спасибо, 
Оказывается, с новыми категориями посетителям стало трудно 


| 

) 

| 

| 

| 

| 

) 

| 

| 

) 

| толь то созданные ато с ранен 
| 
| 
| 
) 
| 
| 
| 
) 
| 
) 
| 


ОРРАТЕ иломефа Бе 
ЅЕТ саедогу = 
САЅЕ 
МУНЕМ сафедогу = ‘драма-г ТНЕМ ‘драма’ 
МНЕМ сафедогц = ‘комедия -г ТНЕМ ‘комедия’ 
М/НЕМ сафедогц = ‘доевик-г ТНЕМ ‘доевик’ 
\МНЕМ сафедогцу = ‘ужасы-г ТНЕМ ‘ужасе’ 
МНЕМ саёедогц = ‘фаниласилика-’’ ТНЕМ ‘фаниласилика’ 
ЕМ№Р; 


1 


Наконец, удалите столбцы Д/Н, которые нам больше не нужны. 


АТЕВ ТАВЕЕ иломезаЫе 
РКОР СОЁОММ агаила, 
РКОР СОЁГОММ сотлеац, 
РКОР СОБУММ асіои, 
РКОР СОГОММ доғе, 
РКОР СОЕГОММ сесії, 
РКОР СОШОММ Рик Кіа, 
РКОР СОЃОММ сагфоои; 


о на ы ан ыы Е а д ео А 


280 глава 6 


расширение возможности ЅЕГЕСТ 


Трудности с таблицами 


Когда в видеотеке появляется новый фильм, информация о нем заносится в базу данных, 

а его описание становится последней записью в таблице. Информация о фильмах в таблице 
никак не упорядочивается. И теперь, когда пришло время заново расставлять фильмы по 
полкам, возникает проблема. На каждой новой полке помещается 20 фильмов, а на каждом 
из 3000 с лишним фильмов должна присутствовать наклейка с обозначением категории. 
Требуется получить список фильмов каждой категории, отсортированных в алфавитном порядке. 


Вы уже знаете, как обратиться к базе данных с запросом на выборку всех фильмов опреде- 
ленной категории, но теперь требуется каким-то образом упорядочить названия фильмов 
внутри категорий. 


поуіе +ађ1е 


тохіе_14 . Че са} зей 
“7 ҳу 


Ра А ИХ д 
Большое приключение семейное 
Грег: Неизвестные истории боевик 
Безумные клоуны ужасы 


83 
[м СЯ 
Гар 
[5 | прсеведеютиевобя |А | бжык [19-52003 | Небольшая частно 
Бау] но 5202 © лишним 
[в | кочове фило, хр 
ЕЯ = 
90 — И 
== 

93 


илихся 6 видеоплеке. 
Р 


о мозговой 
ШТУРМ 


Как упорядочить данные по алфавиту 
с использованием команды 501? 


перегрузка 5ЕЁЕСТ 


Упорядочение результатов ВыборКи 


На каждом из 3000 с лишним фильмов необходимо разме- 
стить наклейку с обозначением категории, после чего филь- 
мы расставляются на полке в алфавитном порядке. 


Нам нужен список фильмов, в котором внутри каждой 
категории названия упорядочены по алфавиту. Вы уже 
умеете пользоваться командой ЗЕЪЕСТ, можете легко по- 
лучить список фильмов заданной категории, и даже выпол- 
нить выборку по первой букве названия и по категории. 


Но для упорядочения такого большого списка фильмов при- 
дется выполнить огромное количество команд ЅЕІЕСТ. Вот 
лишь небольшая часть: 


ЗЕЪЕСТ &161е, сабедогу ЕВОМ тоуіе бар1е МНЕВЕ біс1е 1ІКЕ 'А%' АМО сабедогу = 'семейное'; 
ЅЕІЕСТ &1Е1е, саседогу ЕВОМ тоуіе ёаріе ИНЕВЕ ііёб1е 1ІКЕ 'Б%' АМР сафедогу = 'семейное'; 
ЗЕЪЕСТ &1&1е, сафедогу ЕКОМ тоу1е_фаБ1е ИНЕВЕ ёіё1е ІІКЕ 'В%' АМр сакедогу = 'семейное'; 
ЗЕТЕСТ &1&1е, сафедогу ЕВОМ тоуіе фаБ1е ИНЕВЕ ёі1е ТТКЕ 'Г%' АМ сафедогу = 'семейное'; 
ЗЕЬЕСТ &161е, сабедогу ЕВОМ тоуіе фаБ1е ИНЕВЕ &1%1е ГТКЕ 'Д%' АМр сафедогу = 'семейное'; 
ЗЕІЕСТ &161е, сабедогу ЕКОМ шоу1е сар1е МНЕВЕ біб1е 1ІКЕ 'Е%' АМО са®едогу = 'семейное'; 


ЅЕІЕСТ &1%1е, сабедогу ЕВОМ тоуіе Еар1е ИНЕКЕ +1%1е ГТКЕ 'Ж%' АМ сафедогу = 'семейное'; 


К. а. 7 И 


ние, чилобы т 
Нужно знамо К и Буква, с коилорой Каилегория, 6 ко- 
К юм, н Е Уі 
найили сам Фил наклейкой ачинаеился назва орой осущесил- 
чилобы снабдииль его ние фильма. вляеился поиск. 


и посилавииле на ио^кУ: 


А еще не задудьиле о фильмах, названия коилорых начинаюил 
ся с иифры («101 далмаилин» или «зоо сларианиев»). 


о мозговой 
омо 


Как вы думаете, где в этом списке будут 
находиться фильмы, названия которых 
начинаются с цифры или неалфавитного 


символа (например, с восклицательного 
знака)? 


> 


расширение возможности ЅЕГЕСТ 


«_ Возьми в руку карандаш 


Чтобы определить правильный порядок записей, нам все равно 
қ, придется вручную упорядочивать названия фильмов по буквам, 
следующими за начальной «А». 


Перед вами результаты одного из 200 (или около того) запросов. 
Попробуйте расставить названия фильмов по алфавиту вручную. 


ЗЕТЕСТ &161е, сабседогу ЕВОМ тоуіе ёбар1Іе МИНЕКЕ біё1е ІІКЕ 'А%’ АМр саїедогу = 'семейное'; 


=” Часиль результлаилов запроса 


[ное | 
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возьми в руку карандаш. решение 


«Возьми в руку карандаш 


РЕШЕНИЕ Чтобы определить правильный порядок записей, нам все равно 
к. придется вручную упорядочивать названия фильмов по буквам, 


следующими за начальной «А». 


Перед вами результаты одного из 200 (или около того) запросов. 
Попробуйте расставить названия фильмов по алфавиту вручную. 


ЗЕЪЕСТ їії1е, сакедогу ЕВОМ тоуіе ёар1іе МНЕВЕ &1%1е ГТКЕ 'А%' АМР сафедогу = 'семейное'; 
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семеиное 


семеиное 


асле ЦИ 

А Когда я Вырастјр 

СОИ 

Аар 2 [ еемейное | 
[Авантюрный роман | семейное 
_АКВананацсты | семейное 
Амаа В отране «удес | семейное 
_Алягќа: Страна досоевї | семей 
[Аморшаная мечта 
Авы 
[Анна породит 
[Античный мир 
 Апеньсиновый феи 
 Арацсобое мао 
 Арбүзная кет 
[Астронавты 
 Асфаньтовые прай 


Ангелы 
Апельсиновый джем семейное 


глава 6 


Сколько времени вам 
потребовалось на то, 
чтобы упорядочить эти 
20 фильмов? 


А представляете, как 
долго придется возиться, 
если фильмов будет 
более 3000? 


расширение возможности ЅЕГЕСТ 


ОКОЕК ВУ 


Хотите упорядочить результаты своего запроса? Это совсем не- 
сложно — включите в команду ЗЕЪЕСТ ключевые слова ОКрЕК 
ВҮ и имя столбца таблицы. 


П, = 
А А / ЅЕТЕСТ &1Е1е, сабедогу 
же, как 6 илолько ЕРКОМ тоуіе бар1е 


чило выполненной 


команде ЅЕ1 Ест: МНЕВЕ 
5 Еіб1е ІІКЕ 'А$' 


А воил эмлого раньше не АМО 
было... Эила часиль озна - сафедогу = псенемасе? 


чаеил, чило запрос должен , 
вернуиль данные уиоряӣ > ОВрЕВ ВУ +і+1е; 
доченными 6 алфавиил- 

ном порядке по значению 

силолдиа «НЕЕ». 


Хотите сказать, что это единственный 
способ упорядочения результатов? 
Да я НИ ЗА ЧТО не стану этим заниматься 
для каждой буквы алфавита. 


г. Возьми в руку карандаш 


И верно. Что следует убрать из этого 
к. запроса, чтобы расширить его воз- 
можности? 


СТОП Выхюолнихое эро упражнение 


До троГо, как перевернетре стрраницу, 
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ключевые слова ОРОЕР ВУ 


Упорядочение по одному столбцу 


Если включить в запрос условие ОВРЕВ ВУ &1%1е, нам уже 


не придется отбирать названия, начинающиеся с опреде- 
ленной буквы — запрос сам вернет данные, выстроенные 
в алфавитном порядке по значению столбца Е1+Е1е. 


Для этого нужно лишь исключить из запроса условие 
сіс1е ШІКЕ, а ОВОЕВ ВУ &1Е1е сделает все остальное. 


„ Возьми в руку карандаш 
` е ПЕВА Что следует убрать из это- 


Ч го запроса, чтобы расши- 


рить его возможности? 


ЗЕЬЕСТ %161е, сабедогу 
ЕВОМ тоуіе фаБ1е 
МНЕВЕ 


АНА 


сафедогу = 'семейное' 
ОВРЕВ ВУ +і+1е; 


ЅЕІЕСТ +181е, саедогу 
ЕВОМ тоуіе +аріе 
ИНЕКЕ 


саёедогу = ' семейное ' 
А ОВРЕВ ВУ бі#1е; 
На эилоил раз дц- Реа. 


деил Выведен полный И ЧМО еще ЛУЧИЁ; 


список фильмов из 
каилегории <«семей- 
ного кино». 


6 список ду- 
коилорых начинаются с иифры. 
начале списка. 


Эило не все резульглаи^ 
не хваилиил месила, ЧИ 


все названия д0 букве 5 
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дцил включены филеме", названия 


Они бидцил находиилься в самом ЕО 273 
ы выборки; нам 
обы привесили 


ОКРЕК ВУ позволяет 
отсортировать данные 
любого столбца. 


1 безумный пришелец 
[_/ 13-й день рождения \ | семейное | 
| 3001 способ потерпеть неудачу | семейное | 
||  8руклучше2 || семейное | 


Асфапьтовые гл. семейное 


расширение возможности ЗЕГЕСТ 


Создайте простую таблицу, состоящую из единственного столбца СНАВ (1) 
с именем «ез{ сһагѕ». 


пр ажнение Вставьте в нее числа, буквы (верхнего и нижнего регистра) и не-алфавитные 
символы, приведенные ниже (каждый символ вставляется в отдельную 
запись). Вставьте пробел и оставьте одну запись со значением 011. 


Примените к столбцу запрос на выборку с новой конструкцией овреВ ВУ. 
Заполните пустые места в книге. 


0123АВСрарса! в#$%^&* () – += [] 
УЧ Ьо А 


У 


Правила 801 


Правила 801 ните запрос ОКрЕБ ВУ 
Выполните запрос ОВОЕВ ВУИ залол сставьте ЭТИ СИМВОЛЫ В по- 
те пустые места, руководствуясь пора, "яде иэс оледОанен е резупьтатаў. 


ком символов в результатах выбор, 


" 
& — 
| Не-алфавитные символы следуют ( 


ый. 
цифр. е? \ а 


Помнииле, как 
Цифры следуют _____. текстовых Всилавииль апо- 


символов. силроф? Эмо 
не илак иросило. 


Значения МОШ следуют цифр. 


Значения МОШ. следуют 
ВИТНЫХ СИМВОЛОВ. 


Символы верхнего регистра следуют 
символов нижнего регистра. 


«А 1» будет следовать 
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упражнение. решение 
Создайте простую таблицу, состоящую из единственного столбца СНАХ (1) 
с именем «{ез{ спагз». 
Вставьте в нее числа, буквы (верхнего и нижнего регистра) и не-алфавитные 


А ажнение символы, приведенные ниже (каждый символ вставляется в отдельную за- 
ра пись). Вставьте пробел и оставьте одну запись со значением Мот. 


Примените к столбцу запрос на выборку с новой конструкцией ОКРЕК ВУ. 
Заполните пустые места в книге. 


Возможный порядок следо- 
а 
и вания символов 6 резуль - 
илаилах выдорки. Обраилииле 
Внимание на пробел в на- 


|" #58 | () "т С“ /0123 е2 чале. Ваш порядок можеил 
?@АВСрР| \] 2094, арса { | } ~ быиль немного другим 6 


зависимосили оил РСУБД: 
Важно понимаиль, чило 
порядок СУЩЕСТВУЕТ — 
и знаиль его для вашей 
РСУБД. 


Правила $01 


ните запрос ОВРЕВ ВУ 
О авьте ЭТИ СИМВОЛЫ В поряд- 
ке мх следования в результатах, 


( & = п 


Правила 500 


Выполните запрос ОВОЕК ВУ и запо, 
те пустые места, руководствуясь по, 
ком символов в результатах выбор, 


Не-алфавитные символы следуют 
до и после 


Цифры следуют до текстовых 
символов. 


цифр. 


Значения МОШ. следуют „20. алфа- 


ВИТНЫХ СИМВОЛОВ. 


расширение возможности ЗЕЁЕСТ 


ОКОЕК с двумя столбцами 


Похоже, все идет прекрасно: мы можем расставить фильмы по алфа- 
виту и построить алфавитный список для каждой категории. 


К сожалению, директор придумал 
для вас еще кое-что... 


К счастью, в одной команде 
можно упорядочить данные 
сразу по нескольким столбцам. 


соналу видеотеки 
То: Пер У 


Е Директор р 
я Долой старый хлам 


Всем привет, 


еко- 
Я думаю пришло время избавиться от неа. 
и ны 
они фильмов, которые были рен 
авно. Можете составить список Фиг га 
дей категории, упорядоченный по д 
приобретения? 


Жду с нетерпением, 
Ваш директор 


Дама приобреи“е- 
ния включается 
6 резульилаи^ 


д выборки. 


ЅЕ1ЕСТ ©1%1е, саедогу, рагксразеа 


ЕВОМ поуіе КаБ1е 


ОВРЕВ ВУ сафедогу, ригсһаѕей; 


КА 


Силолдец первичной сортировки. 
Мы получим список всех фильмов 
8 магазине, упорядоченный 

ло силолдиу «сайедогу». 


7 


А мо эмломЧ силолбиц будем вы- | 
лолняилься вилоричная сорилиро 5 
ка ПОСЛЕ сорилировки ко силолёцу 
<‹сафе40"Ч”. 


0 мозговой 
ШТУРМ 


Где будут находиться самые старые фильмы — 
в начале или конце каждой категории? И что 


произойдет, если два фильма в одной категории 


имеют одинаковую дату приобретения? Какой 
из них окажется на первом месте? 
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сортировка по нескольким столбцам 


ОКОЕК с несколькими столбцами 


Возможности сортировки не ограничиваются всего двумя столбцами. Д Но 
Вы можете выполнить сортировку по любому количеству столбцов, анные мо 


чтобы получить нужную информацию. 
отеортировать 
Взгляните на следующую конструкцию ОВРЕВ ВУ с тремя столбцами. 
Ниже показано, как происходит сортировка. По любому 
ЗЕБЕСТ * ЕВОМ шоу1е фаБ1е 


: количеств 
ОВОЕВ ВУ сабедогу, ригсһаѕеа, +1+1е; у 
Сначала резульилаилы Члорядочи - г (упорядочен- столбцов. 
Ванился ио силолбиу «сафедоғу», Затем резулеглаилы (9 И с 
иоилому чило он находиился на ’ ные ио каилегориям, нач и 
ербол месте в списке ОКРЕВ  сормируюмся 70 ру всегда 
ВУ. Каилегории упорядочиваюил_ самых СМАР! даил. Д Е 
ся ом А д0 Я. сорилируюился по го0ц ав Наконец, резуль- 
ЈА месяцу, и в завершение ио дням. илаилы уилоря- 
дочиваюился по 
Категории названию фильма, 
А илакже в порядке 
ом А до Я. 
приобретения 
20-11-1999 --4----> Названия 
А 
я 


Названия 


| 


19-4-2003 


приобретения 
20-11-1999 --4---- >. Тез 


Ѕѕёагёіпо мБ 
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расширение возможности ЗЕЁЕСТ 


Упорядоченная таблица 


Давайте посмотрим, какие данные вернет коман- 
да ЗЕТЕСТ для исходной таблицы фильмов. 


ксвазей 
г > 


Исходная А АХ, 2 д 
илаблица 6-3-2002 


илом аре. 


| укы [2099 | 

а | бек | 19-2003 | 

[к [| ре | 522001 | 
> № |  Беашевыи | №6 | деж | 63200 | 

о - 

лт 

Рт 


Никакого 07 
рядка здесь 

неи; фильме 
иеречислЯ- 
оился В ио- 
рядке Всилав - 
ки записей 
в илаблицу. 


Ч 


Планета пригодна для жизни 


“9 “р речем ДА 


4 


...м упорядоченные результаты нашего запроса: 
Первичная 
Заверманющая сорилировка 


сорилировка < 


Грег: Неизвестные истории боевик 


Параскеведекатриафобия боевик 


Вилоричная 
сорилировка 


Заберите обратно 


Конец очереди 


Разгневанный пират 


Большое приключение 
Крыса по имени Дарси 
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обратный порядок 


слово РЕЗС. 


часто 


Не люблю старое кино... А если я захочу 
сначала увидеть новые фильмы? Неужели 
придется читать список от конца к началу? 


В аі есть ключевое слово для изменения 
направления сортировки. 

По умолчанию 501. упорядочивает столбцы ОВРЕВ 
ВУ по возрастанию: от А кЯ, от 1 к 99999 ит. д. Если 
вы предпочитаете получить данные в обратном 
порядке, укажите после имени столбца ключевое 


адаВаеМые 


Вопњсь 


* Но мы использовали ключевое слово рЕЅС для полу- 
чения ОПИСАНИЯ таблицы. Вы уверены, что оно может 
использоваться для изменения порядка? 


() Да, все зависит от контекста. Если поставить РЕЗС перед 
именем таблицы — например, рЕЅС тоуіе ёар1е;– то вы 
получите описание таблицы. В этом случае оно интерпретирует- 
ся как сокращение от РЕЗСВТВЕ. 


В условии ОВРЕХА оно интерпретируется как сокращение 
от ВЕЗСЕМОТМС, и определяет порядок результатов. 
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"я могу использовать в своих запросах полные слова 
ТЕЅСВІВЕ и РЕЅСЕМ”ІМС, чтобы избежать путаницы? 


(} Вы можете использовать РЕЗСВТВЕ, но РЕЅСЕМРІМС 
работать не будет. 


Ключевое слово РЕЅС поеле 
имени столбца в условии 
ОКРЕК ВУ упорядочивает 
результаты по убыванию. 


расширение возможности ЅЕГЕСТ 


0ЕЅ0 и изменение порядка данных 


Представьте, что ваши данные стоят на ступеньках 
лестницы. Когда вы поднимаетесь по лестнице (дан- 
ные упорядочены по возрастанию), буква А попадется 
вам раньше буквы Б. Когда вы будете спускаться (дан- 
ные упорядочены по убыванию), первой на вашем 
пути попадется буква Я, а последней — буква А. 


Следующий запрос возвращает список фильмов, упо- 
рядоченных по дате приобретения, начиная с самых 
новых. Для каждой даты фильмы, приобретенные 

в этот день, перечисляются в алфавитном порядке. 


ЗЕБЕСТ +іє1е, ригсвазеа 

ЕВОМ тоуіе фаЪ1е 

ОВОЕВ ВУ +іё1Іе АЗС, ригсһаѕеа рЕЅС; 
7 ) 


Здесь можно указаиль клю - 


чевое слово АЗС, но эило не Чилобы данные богли Я 
обязаилельно. Досилаилочно оилсорилированы А 

иомнииль, Чило по умолчанию до А (или ои а до 7А 
данные сорилируюился по Воз - используйте ключебо 


расиланию. слово РЕЅС. 
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от фильмов к печенью 


То: Персоналу видеотеки 
Егот: Директор 
Ѕибјесё: Налетай! 


Всем привет! 


Все просто прекрасно! Фильмы стоят на нуж- 
ных местах, и благодаря этим вашим хитро- 
умным условиям ОКОЕК ВУ каждый клиент 
может легко найти именно то, что ему нужно. 


Чтобы наградить вас всех за примерную ра- 
боту, завтра в моем доме состоится вечерин- 
ка с пиццей. Собираемся к 18:00. 


И не забудьте принести отчеты! 
Ваш директор 


Р. $. И не слишком наряжайтесь, мне тут 
нужно передвинуть кое-какую мебель... 


294 


глава 6 


расширение возможности ЗЕЁЕСТ 


Проблемы с печеньем 


, евочка, Зарабоиланная 
Руководитель местной группы девочек- Ир одавилая сумма Дама 
скаутов пытается разобраться, кто из ее печенье МЎ соокіе за1ез ее и продажи 


подопечных продал больше всего пече- 
нья. Покау нее есть таблица с данными 
о продажах каждой девочки за день. 


овен аб 
Я должна как можно 


скорее определить 
победителя. 


ЕЕ | 

ВЕ) 

ата 1896: 1 

5 | Лим | 956 | 73-2007 | 
[ 65 | пэрис | 1.52 [| 73-2007__ 
[ 7 | вии | 43” | 7-3-2007__ 
[ 8 | Нижоль | 8.05 [| 73-2007__ 
Вы 8-3-2007 
0829) 8-3-2007 
м | Бритни | 340 | 8:3-2007 
[ 2 | николь | 1521 | 8:3-2007__ 
[ 3 | линди | 0 | 93-2007 | 
[ м4 | Пэрис | 3199 | 93-2007 __ 
в | Бим |] 2.58 | 9:3-2007 | 
[ 6 _ ноль | о | 933-2007 _ 
Е [234 | 10-3-2007 | 
в | Пэрис | 344 | 10-3-2007 
[ №9 | Бритни | 878 | 10-3-2007 | 
Е 82 | 10-3-2007 _| 
21207 п] 13-2007 _| 
|2 | Пэрис __] 056 | 11-3-2007 _| 
[23 | Бритни | 349 | 13-2007 _ 
[24 | николь | 777] 1-3:2007_| 
[25 | Линды | 16.23 | 12-3-2007 _ 
[26 |] Пэрис | 0 | 12:3-2007__ 
| 27| Бритни | 450 | 12-3-2007 | 
[Николь | 1922 | 12-3-2007 | 


Эдвина, руково- 
диилель груииы 


„Возьми в руку карандаш 
еы Девочка, продавшая больше всего печенья, награждается бесплатными 
уроками верховой езды. Все девочки хотят победить, поэтому Эдвине 
очень важно побыстрее определить победителя, пока дело не дошло 
до ссоры. 


Используйте свои навыки обращения с ОВОЕВ ВУ и напишите запрос, 
который поможет Эдвине узнать имя победителя. 
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возьми в руку карандаш. решение 


_ Возьми в руку карандаш 
е’. р РШениё Девочка, продавшая больше всего печенья, награждается бесплатными 
уроками верховой езды. Все девочки хотят победить, поэтому Эдвине 
очень важно побыстрее определить победителя, пока дело не дошло 
до ссоры. 


Используйте свои навыки обращения с ОКРЕК ВУ и напишите запрос, 
который поможет Эдвине узнать имя победителя. 


СЕРЕСТ Ёк паиле, ѕа[еѕ 
ЕРОМ сооКге_ва[ез 


ОВрЕР ВУ ЁЁ маиле; еы 
Эило запрос... 


х ..@ эило его резульилаилы. 


м 


| ево |_ мов" ^ 
Г Нико [000 | 


96.05 


Чилоды определить ио- 
бедиилеля, нам все равно 
10791 &—————__ иридется складываиль 
данные о продажах каж- 
дой девочки вручную. 


Пэрис | 0.00 
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расширение возможности ЗЕЕЕСТ 


Ѕ0М сложит числа за нас 


Ставки высоки. Мы не можем допустить ошибку и рассердить девочек-скаутов. Одна- 
ко числа не обязательно складывать вручную — «черную работу» можно поручить $501. 


В языке 501. есть специальные ключевые слова, называемые функциями. Каждая 
функция выполняет некоторую операцию с одним или несколькими значениями. 
Первая функция, которую мы вам покажем, выполняет математическую операцию 
со столбцом. Функция 50М суммирует значения столбца, указанного в круглых скобках. 
Давайте посмотрим, как она работает. 


Функция Ѕ0М суммируеи 
Значения силолёца <ва(ес», <ИМ — финкция, ило есть эило 
м ключевое слово Выполняеил оме ~ 


рацию со силолбиом, указанным 


ЗЕЦЕСТ $ОМ (ѕа1еѕ) в круглых скобках. 
ЕРОМ сооКкіе за1ез 


ИНЕРЕ Ягзе папе = !'Николь!'!; 
Е. г 


Эило условие ограничиваеил запрос, чилобы он скла- 
дывал илолько данные продаж Николь. Без него запрос 
иросуммируеил все содержимое силолбца <ва{ез>. 


Ее Еа У/падом Нер Тне\/Иппей$ 
> ЅЕГЕСТ $9М(з5а1ез) ЕКОМ соок1е за1ез 
-> ИНЕВЕ Е1х5% паме = ‘Николь’; 
----+ 
ЗУМ (ѕаїеѕ) 


| 
+ 
96.03 | 
ЕЯ 


1 рон іп ѕеї (0.00 ѕес) 


Теперь осталось вычислить еще три суммы, и наша работа 
завершена. Однако было бы намного проще и удобнее 
сделать все в одном запросе... 


Попробунте’”сами 


Попробуйте сделать это самостоятельно. Создайте таблицу, похожую на соокіе за1ез, 
вставьте в нее несколько чисел и проверьте, как работают запросы, приведенные на не- 
скольких ближайших страницах. 


пражнение 
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СКОУР ВУ хорошо работает с ЗИМ и АУС 


Суммирование с использоВанцем СКОЦР ВУ 


Данные о продажах печенья всеми девочками можно просумми- 
ровать в одном запросе — для этого в команду 50М включается 
условие СКООР ВУ. Такая команда группирует все записи с именем 
каждой девочки и суммирует данные продаж в каждой группе. 


р о буммируем данные 
ЅЕТЕСТ Ягзе пате, $ОМ(за1ез) силолбиа <5ще5>». 


ЕВОМ сооКкіе за]ез Груипирцеил значения 
СВОЦР ВУ ЯгзЕ пате «7 Силолдца «Ну удиле»». 
ОВРЕВ ВУ 50М(ѕа1еѕ)рЕЅС; 


мй 
Упорядочение по той же функ - 
ции ЗУМ, которая использова - 
лась для выборки. ж ЕЕакае 


оманда ( ДАЛАЛ 072) 
+ сил Л 17 «све >> рии 


[и и 
БЕРАРА а каждого значения «Низ. и к 
заїез_| ЗАО | 

Ер» 
Николь Г в1е8_| Линдси | 17.62 
26.53 | Линдси | 946 | | Бритни | 4.50 | 


Значения должны Выводиилься 
`——— ^о 90ыванию, чилобы нам было 
проще определииль победиилеля, 


Николь _Г 2682 [Пэрис |000 [| линдси | 00 врим | п 


| Ріе ЕФА_УИпбом Нер ТпеМппегҚеауіз ОО (М}_  БЮВЭозамвжг о адмнмге 
> ЗЕЪЕСТ #ігѕё пате, 50М(ѕа1еѕ) 
-> РВОМ соокіе ѕа1еѕ СВОПР ВУ Ғігѕі пате 
-> ОВОЕВ ВУ 50М(ѕа1еѕ); 
+ +—----------- + 

| ЕзхзЕ пате | зим (за1ез) 
Побеждаем^... — № —- 
Бриилни! > аи 107.91 
Пэрис 
Николь 


Линдси 


| 
| 
| 
| 
+ 
4 


гомѕ іп ѕе (0.00 ѕес) 
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Функция АМС с СКОУР ВУ 


Другие девочки были огорчены, поэтому Эдвина решила вручить 
второй приз за высший средний объем продаж за день. Для его вы- 
числения она использует функцию АУС. 


Каждая девочка продавала печенье семь дней. Для каждой девочки 
функция АУС суммирует ее продажи, а затем делит их на 7. 


‚ но на эилоил раз вВычисляеился 


ые грцими- 
И снова данн г не сумма, а среднее значение. 


руюился по значению 

Ни маиле... У 
ЗЕЦЕСТ ЯгзЕ пате, АУС (за1ез) 
ЕВОМ соокіе за1ез 


= АМа суммирцеил все 
СВОЦПР ВУ ЯгзЕ пате; груииы и ЕНА А о 


количесилво значений, чилобы 


— Определить среднее значение 7 
Ж, для группы. у, 


пее ване [ ваз | 
[Николь | 0.00 | 
Николь | 2682 | Гр | 0.0 _ 


Пей пате | зайю5 | 


Ене Ек Уйпдом Нею Тпе\Иппе Кеа!у!з 


И снова иобе- > ЗЕЪЕСТ Е1г5е пате, АУС (за1ез) 


дила Бриилни... -> ЕВОМ соокіе за1ез СВОПР ВУ Ғігѕі пате; 
Нужно ири- _ н * 
думаиле другой Е1гзЕ пате | АУС (за1ез) 
способ опреде - " 
ого 

ления вилор Николь ЗТБ 
месила. 

<> 7 15.415714 


Линдси 11.582857 
Пэрис 14.032857 


гомѕ іп ѕе (0.00 зес) 
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ММ и МАХ в действии 


МІМ и МАХ 


Не желая сдаваться, Эдвина применяет к своей таблице функ- 
ции МІМ и МАХ. Она хочет узнать, не было ли у других девочек 
более высоких продаж за день — а может, в свой худший день 
Бритни заработала меньше других? 


Для определения наибольшего значения в столбце исполь- 

зуется функция МАХ, а для определения наименьшего значе- 

ния — функция МТМ. 

МАХ возвращаем 

чение 

ЗЕГЕСТ ЯгзЕ папе, МАХ (за1ез) ое 
Иа и у 

ЕВОМ соок1е за1ез 

СВОПР ВУ ЯгзЕ папе; 


нь: 


| Вга? пате | зе | 


Сюририз' 
Самая боле- 


шоя выручка —> 
за дене снова 
у Бриилни, 


ЗЕЪЕСТ Ягзё папе, МІМ(зајез) <— ММ озбращаем 
ЕВОМ соок1е_за1ез из каждой ры. У 
СВОПР ВУ бгѕі пате; 


[Яга пате |__вајов 
[ Николь | 0.00 | 


Похоже, ц всех 
осилальных де- 
вочек был хоиля 
ды один выходной, 
а у Бриилни даже 
6 худший день 
был зарабоилок. 


Это уже серьезно. Может, дать приз 
девочке, которая продавала печенье 
больше дней, чем другие? 


—.—^. 
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СОУМТ и подсчет дней 


Чтобы узнать, какая из девочек продавала печенье больше дней, 
чем другие, Эдвина пытается использовать для подсчета функцию 
соомт. Функция СООМТ возвращает количество записей в столбце. 
Е Функция СОИМТ возвращаеил 
количесилво записей 8 силолбие 


ЅЕТЕСТ СООМТ (за1е Аафе) «са[е Дафе». Если запись со- 


ЕВОМ соокіе за1ез; держиил МОГ, она не включа- 
— еился В подсчеил. 


«Возьми в руку карандаш 


соокіе за1ез 


| геї пате | заеё | зо Че | Перед вами исходная таблица. Как вы думаете, 
какой результат вернет запрос? 

Представляет ли это число количество дней, 
в течение которых продавалось печенье? 
Линдси | 0 | 93-2007 | 
Николь | 0 | 93-2007 | 

Напишите запрос, который будет возвращать 
количество дней, в течение которых каждая 
девочка продавала печенье. 

пэрис Г 56 | 32007 | 


.56 
[При | 0 | 123-2007 | 
12-3-2007 
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Возьми в руку карандаш 
: Решение 


Перед вами исходная таблица. Как вы думаете, какой 
результат вернет запрос? 


2.8 дней 


Представляет ли это число количество дней, в течение 
которых продавалось печенье? 


Неил. Оно иредсилавляеил количесилво 
значений 6 силолбце «вае_дафе>. 


Напишите запрос, который будет возвращать количе- 
ство дней, в течение которых каждая девочка продава- 
ла печенье. 


СЕЁЕСТ Вуз мамле, СООМТ(ѕаіе даће) 
ЕКОМ соокіе_ѕа(є5 
СКОЧР ВУ ЁкѕЕ мамле; 


Чтобы узнать, сколько дней 
продавалось печенье, можно было 
упорядочить результат по ѕаіе_аће, 
и вычесть из последней даты первую. 
Правильно? 


Вообще-то нет. Мы не можем быть 
уверены в том, что между первой 

и последней датой не было пропущенных 
дней. 

Существует гораздо более простой способ узнать, 
в течение скольки дней продавалось печенье. 
Задача решается при помощи ключевого слова 
рІѕтІМСТ. Оно поможет нам не только вычислить 
нужное значение СООМТ, но и получить список дат, 
не содержащий дубликатов. 
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Команда ЗЕТЕСТ 018ТІМСТ Так как РІЅТІМСТ — ключевое 


слово, а не функция, имя силолб ~ 
Для начала посмотрим, как работает ключе- 


ца <вайе_Чафе» не нужно заклю _ 
вое слово ОТЗТТМСТ без функции СООМТ. 2 чаиль 6 круглые скобки. 


ЗЕГЕСТ ОТЗТТМСТ за1е Ча®е 


ЕВОМ соокіе за1ез Условие ОВРЕВ ВУ улрощавил поиск 
ОВРЕВ ВУ за1е Чафе; <—— первой и последней даилы продажи. 


Ріе Еак Улпдом Неір МоПирез 
> ЗЕЪЕСТ ЮОІЅТІМСТ за1е даїе 
ЕВОМ соокіе за1е5 
-> ОБОЕВ ВУ за1е абе; 
+ 
за1е дае | 
+ 
2007-06-03 
2007-07-03 


Смоилрииле: 2007-08-03 
ни одного 2007-09-03 
дибликаила! 2007-10-03 
2007-11-03 
2007-12-03 

+ 


гомѕ іп ѕеі (0.00 ѕес) 


Теперь попробуем выполнить команду с функцией СООМТ: Обраилииле Внимание: РИ5ИМСТ 
заключаетлся 6 круглые скобки 


А вмесиле с <<ѕаіе_ даће»). 
ЗЕТЕСТ СООМТ (0ІЅТІМСТ за1е даёе) 
ЕВОМ соокіе за1ез; | 
У 25 МОЗГОВОЙ 
У ШТУРМ 


Попробуйте выполнить этот запрос. 
Кто из девочек продавал печенье в 
течение большего количества дней? 


Условие ОРРЕв ВУ не нужно, 
ломому чило СООМТ вернеил 


одно число. Улорядочиваиль 
здесь нечего. 


инмииа Ч :%м29%м0 
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кто я? 


304 


Компания функций и ключевых слов 501, облаченных в ма- 
скарадные костюмы, развлекается игрой «Кто я?» Игрок дает 
подсказку, а остальные на основании сказанного им пытаются 
угадать, кого он изображает. Будем считать, что игроки всегда 
говорят правду о себе. Заполните пропуски справа именами 
одного или нескольких участников. Также для каждого участ- 
ника укажите, является ли он функцией или ключевым словом. 


Сегодняшние участники: 
СОЧМТ, ОІЅТІМСТ, АМС, ММ, СВОУР ВУ, $0М, МАХ 


Мой результат не выглядит большим. 


Мой результат больше любого из входных значений. 


Мои результаты единственные и неповторимые. 


Я скажу, сколько здесь было значений. 


Используйте меня при вычислении суммы. 


Меня интересуют только большие числа. 


Как дела? Да так, средне. 
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фунКция или 
Ключевое слово 
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Вось 


* А могли ли мы добавить условие ОВРЕЕ ВУ при 
поиске средних/наибольших/наименьших значений 
с использованием АУС, МАХ и ММ? 


() Могли — более того, это была бы очень хорошая 
идея. Мы не стали включать ОКРЕА ВУ, чтобы не ус- 
пожнять запросы и упростить изучение новых функций. 
Вернитесь к этим функциям и представьте, к каким 
последствиями привело бы применение ОВРЕК ВУ. 

Вы видите, как изменятся результаты? 


‚ Ключевое слово ОІЅТІМСТ выглядит весьма 
полезным. Его можно использовать с любым 
столбцом? 


() Да, с любым. Оно особенно удобно, когда один 
столбец содержит одинаковые значения у нескольких 


записей, а вы просто хотите просмотреть уникальные 
значения вместо длинного списка дубликатов. 


|: Запрос с МТМ () никак не помог бы Эдвине опре- 
делить победителя, верно? 


(} Верно, но Эдвина смогла узнать, кто из девочек тру- 
дился хуже других. На следующий год она постарается 
обратить на лентяев особое внимание. 


: Раз уж мы заговорили о МТМ — что произойдет, 
если в столбце встречаются МО? 


(} Хороший вопрос. Нет, ни одна из этих функций 
никогда не возвращает МОТ, потому что МОТТ, — это 
отсутствие значения, а не нуль. 


Хм... АУб, МАХ и СОУМТ 
так и не помогли мне определить второе 
место. Придется воспользоваться 50М, 
вычислить, кто из девочек оказался на вто- 
ром месте по продажам, и наградить. 


С МОЗГОВОЙ 
ОЎГШТУРМ 


Представьте, что в таблице хранятся 


данные не четырех, а сорока девочек. Как 
использовать 50м для определения второго 


места? 
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ИМИТ и ограничение результатов 


Итак, мы будем использовать 50М для определения второго места. Давайте 
вернемся к исходному запросу и результатам, чтобы понять, как получить 
нужную информацию. 


ЅЕГЕСТ Ғігѕі пате, $ОМ(за1ез) 
ЕВОМ сооКкіе за1ез 
СКООР ВУ Ғігѕё пате 
а; ОВРЕВ ВУ 50М (ѕа1еѕ) рЕЅС; Нас инилересуюи^ 


первые 
Очень важно использовать илолеко лер 


А ила. 
здесь условие ОКРЕВ ВУ 0031. роте —|—аез | два резулвила 
6 ироиливном случае рет 07.91 | 
зильилаилы бидцил следо- = 
Ваиль В случайном порядке. 


Парме на Вилором 
АЕС! Николь с 
нец дольше не раз- 

С четырьмя результатами нетрудно увидеть, кто оказался на втором месте. говариваеил. 

Но если вы хотите действовать еще точнее, ограничьте список данными двух 

девочек с наибольшими объемами продаж. Ключевое слово ГТМТТ позволяет 

указать количество записей, возвращаемых запросом из итогового набора. 


ЗЕЦЕСТ бгѕі пате, 50М (за1ез) 
ЕВОМ соокіе за1ез 
СВОЦР ВУ бгѕі пате 
ОВРЕВ ВУ 8$0М (ѕа1еѕ) рЕЅС 
СА ІІМІТ 2; Эилоил длинный заирос воз- 


враиаеил всего два числа. 
Означаєеил, чило список 
ОГРАНИЧИВАЕТСЯ лервы – 
ми двумя резульилаилами. 


В таблице хранятся данные всего четырех девочек, и ограничение их до двух осо- 
бой пользы не принесет. Но представьте, что вы работаете с огромной таблицей. 
Допустим, в таблице хранятся описания 1000 самых популярных песен, а вы хоти- 
те отобрать из них первые 100 в порядке популярности. Условие ЬТМТТ позволит 
получить только нужные вам песни, а остальные 900 останутся «за кадром». 
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ИМИ и Второе место 


ІМІТ даже позволит нам сразу определить второе место, без вы- 
вода первого места. Для этого 11МІТ передаются два параметра: 


Если вы момымлаемлесь угадаиль 
смысл эилого условия, мло скорее 
всего, ошибеилесь. С двумя пара - 
мемлрами ЫМИТ рабоилаемл совсем 


не илак, как прежде. р? 


Бриилни — О, 


107.91 


9823 Пэрис — 1, 
РМТ 0,4 9503 | ( Николь — 2, 
и вов —| 2 Линдси — з 
Номер 8 \ 
р начальной р. зврацаа - 
записи. Г 91 а К.оличесилво Во аА 229] 
24 и емых резул“: сыне 
Рация начинаеился со | = 259 
2% 88". 


Еще не забыли наш пример со 100 песнями? Допустим, мы хотим 
получить песни с 20 по 30. Это можно сделать при помощи 11МІТ 

с дополнительным параметром. Упорядочите песни по популярности 
и добавьте условие 1ІМІТ 19, 10. Параметр 19 указывает, что вывод 
начинается с 20 песни (раз в 501. нумерация начинается с 0), а пара- 
метр 10 — что запрос должен вернуть 10 записей. 


«> ВОЗЬМИ в руку карандаш 


Напишите запрос, который вернет второй результат — и только 
2.3 второй результат. В запросе должно использоваться условие 
ІІМІТ с двумя параметрами. 
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Возьми в руку карандаш 
ЫҸ Решение Напишите запрос, который вернет второй результат — и только 


`. второй результат. В запросе должно использоваться условие 
ТТМТТ с двумя параметрами. 


ЅЕГЕСТ Низ маиле, ЅОМ(ѕа[еѕ) 
ЕВОМ соокіё_ѕа[еѕ 
ЯКОЧР ВУ ЁүѕЕ маиле 
ОВрЕВ ВУ ЅОМ(ѕаіеѕ) РЕЅС 
ИМТ 1,2; 
Г Не задудьиле, чило 


начинаеился с О. Та 
на самом деле 2. 


8 ог. Нумерация 
К Чило 1 — эило 


С этими новыми ключевыми словами 
мои команды 50і. стали такими длинны- 
ми и сложными... Все это хорошо, конечно, 
но нельзя ли их как-нибудь упростить? 


Ваши запросы становятся длиннее, потому 
что сами данные стали более сложными. 
К таблице стоит присмотреться повнимательнее — 


возможно, она стала слишком сложной. Пора пере- 
ходить к главе 7... 
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Кто я? 


Компания функций и ключевых слов $01, облаченных в ма- 
скарадные костюмы, развлекается игрой «Кто я?» Игрок дает 
подсказку, а остальные на основании сказанного им пытаются 
угадать, кого он изображает. Будем считать, что игроки всегда 
говорят правду о себе. Заполните пропуски справа именами 
одного или нескольких участников. Также для каждого участ- 
ника укажите, является ли он функцией или ключевым словом. 


Сегодняшние участники: 
СООМТ, рІЅТІМСТ, АУС, ММ, СКОУР ВУ, $0М, МАХ 


функция или 


Цмя 
Ключевое слово 
Мой результат не выглядит большим. мм функция 
Мой результат больше любого из входных значений. 50м функция 
Мои результаты единственные и неповторимые. Ріѕ5тІМСТ ключевое слово 
Я скажу, сколько здесь было значений. СОооОМТ функция 


Используйте меня при вычислении суммы. 


Меня интересуют только большие числа. МАХ функция 


Как дела? Да так, средне. АМа функция 
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краткий обзор 59! 


Новые нетрументы 


Глава 6 осталась позади. Теперь вы с легкостью 
управляетесь с функциями, ключевыми словами 
и расширенными запросами ЗЕТЕСТ. Полный 
список инструментов приведен в приложении Іі. 


ГЛАВА 6 


вает резул 


Упорядоч заданному 


соот 


Соодиаеџл, СКОЛЬКО за - 
пари бозвращаеил запрос 
ЕІЕСТ, дез вывода самих 
записей. соимт вбозвраща- 
ел одно целое число. 


свооР ВТ 
руё” замиси и 
прулаковам значениям 


ЮІЗТІМСТ Аус 


Возвращаеил илолько 
уникальные значения, без 
дидликаилов. 


Во 

ааа среднее 
ие дл 

Силолдцд., Я числового 


50м 


Суммируеи числовые 
значения 6 силолбце. 


МАХ и муу 


МАХ 6036 
Ращаеил 
шее Значение в Ее 2б 
це, 


 Наименьцег 


Определяеил, сколько 
иМенно записей должен 
Рнуиль Запрос, и с ка- 
Кой записи следуеил на – 
чинаиль. 


Ваши новые инсилру ~ У 
менилы: функции, клю- 

чевые слова и расши- 

ренные запросы ЅЕ ЕСТ! 
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х с * 
Когда в одной таблице тесно + 


Мой малыш уже подрос. 
Наверное, он скоро переедет. 


Иногда в одной таблице становится попросту тесно. 
Данные стали более сложными, и с одной таблицей работать уже 
неудобно. Ваша единственная таблица забита избыточной ин- 
формацией, которая только попусту расходует место и замедляет 
обработку запросов. Вы выжали из одной таблицы все, что только 
можно, но окружающий мир огромен, и для хранения данных и ра- 
боты с ними нередко приходится использовать несколько таблиц. 


найджел ищет подружку 


Как найти Найожелу подружку 


Ближайший друг Грега — Найджел — попросил 
ему подобрать подружку с похожими интереса- 
ми. Для начала Грег извлекает из базы данных 

запись Найджела. 


Вот как она выглядит: 


сопеасЕ_14: 341 

Іаѕё пате: Мур 

Ғігѕї пате: Найджел 

рһопе: 5552311111 

етаі1: піде1 тоогеёгапсһегѕгціе. сом 
депаег: М 

рігіһаау: 1975-28-08 

ргоЕез$1оп: Фермер 

сіёу: Остин 

ѕсаёсе: ТХ 

зіаёцѕ: Не женат 

іпіегеѕіѕ: животные, лошади, кино 
ѕеекіпд: Незамужняя женщина 


Столбец 1пЕегез(з не является атомарным; 

в нем хранится несколько однотипных инфор- 
мационных объектов. Грег обеспокоен: похо- 
же, составить запрос будет непросто. 


Грег включает просьбу Найджела в свой спи- 
сок текущих дел. 


Текущие дела 


Написать запрос для Найджела: 


запрос должен Вы- 
Полнять поцск по столбцу пфеге$ 5. Что- Р 


то сложно, Вроде нужно 
ет... 


использовать ИКЕ но на один раз сойд 
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Зачем что-то менять? 


Грег решил не изменять столбец іпсегеѕіѕ. Он пред- 
почитает писать сложные запросы, потому что ему 
кажется, что это придется делать не так часто. 


Грег использует поле даты рождения для поиска канди- 
даток, которые по возрасту отличаются от Найджела 
не более чем на 5 лет. 


«_ Возьми в руку карандаш 


Допишите запрос Грега, чтобы он находил женщин, разде- 
№. ляющих все интересы Найджела. Укажите, что делает каждая 
строка кода. 


ЗЕБЕСТ * ЕВОМ пу сопфас®5$ 
ИМНЕВЕ депаег = 'Ж' 
зсаеа$ = 'Не замужем' 


ѕсаёе= 'ТХ' 

ѕеекіпд ГТКЕ '%Мужчина%' 
Ьрігіһаау > '1970-28-08' 
ЬрігёҺаау < '1980-28-08' 
іпбегеѕёѕ ШІКЕ 
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возьми в руку карандаш. решение 


Возьми в руку карандаш 
ЫҸ Решение Допишите запрос Грега, чтобы он находил женщин, разде- 


Қ, ляющих все интересы Найджела. Укажите, что делает каждая 
строка кода. 


бате ога ты санавы 
ь. › лемлбо _ 
"в дующим условиям. РН 
ЅЕТЕСТ * ЕВОМ ту сопіасёѕ 
ИНЕВЕ депдег = 'Ж Є И Жи. 
зёаёџѕ = 'Не замужем! < ``" З2/Ужнюю.. 
зёаіе='ТХ' = чтобы жила 6 мом же илилаиле... 
ѕеекіпд ТТКЕ '%Мужчина%' <— и хотела лознакомиилься 
ЬігёҺаау > '1970-28-08' р с мужчиной... 
рігёһаау < '1980-28-08' Не долее чем на 5 лерд Млад - 
іпіегеѕіѕз ТТКЕ _ ‘Фжибоилные — 1 “ЛИ Саре Найджела.. 


© 

А здесь имицился совладения 
„...еге$$ КЕ "КИНО... ани. в облечений Найджела также 
можно было использовать ОК, 
но мы хоилим найили совладе - 
ние по всем чвлечениям. 


Запрос прекрасно сработал... 


Грег находит идеальную пару для Найджела: 


сопіасё 14: 1854 
Іаѕё пате: Фиоре 


Е1кзЕ пате: Карла Карла 
рһопе: 5557894855 и Триггер 
ета11: соге Ё іогеапіта1с1іпіс. сот м3) 
депӣег: Ж 

дии 


Ьігіћдаү: 1974-01-07<—— ^00Х0 
ргоЕезз1оп: Ветеринар < хороилая профессия 
сіу: Раунд-Рок 
зфафе: ТХ 

ѕіасиѕ: Не замужем 
іпсегеѕзіёѕ: лошади, кино, животные, детективы, 
туризм 

зееК1па: з1па1е М чнилересы совиаданюил! 


и даже живеил неподалеку 
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...даже слишком хорошо! 


У Найджела и Карлы все срослось, и Грег 
стал жертвой собственного успсха: все 
неженатые друзья просят его найти им 
подругу жизни. А друзей у Грега много... 


Я не могу по- 
стоянно писать такие 
сложные запросы. 


многотабличные базы данных 


Вею «черную работу» должна 
выполнять база данных. Не пы- 
тайтесь обойти плохую структуру 
таблицы при помощи еложных 
запросов. 


Написание запросов занимаёил слиш 
ком много времени. Грег включаем 
в свой слисок дел новую запись. 


у, 
е Текущие дела 


пунио овер стовёцу ліе б-на 


А, 


иїегесіѕ. 


Ф024. 


Написан запрос/9ля Изаджела; 4 я ТТА 
ЛА Еву 


использовать ИКЁ“но на один раз сваден 


АВ будущем как-нибудь обойтись без столбца 


)ецужно 
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без столбца іпќегеѕіѕ 


Игнорировать проблему — не Выход 


Другой друг, Реджи, просит Грега найти ему пару. Ему нужна 
женщина, которая отличается от него по возрасту не более 
чем на 5 лет. Реджи живет в Кембридже, штат Массачусетс, 
а его увлечения отличаются от увлечений Найджела. 


Грег решает вообще не обращать внимания на столбец Реджи 7 
іпіегезѕізѕ, чтобы не усложнять запросы. 


Напишите для Реджи запрос, не использующий столбец іпіегезіѕ. 


\ 


пражнение 


солёасё іа: 873 

Іаѕё пате: Салливан 

Ғігѕї пате: Реджи 

рһопе: 5552311122 

етаі1: теёкаёћіе1ееіѕа#1аке. сот 
депаег: М 

Б1кЕпаау: 1955-20-03 
ргоҒеѕѕіоп: Комик 

сіїу: Кембридж 

ѕсасе: МА 

зіаіцѕ: Не женат 

іпёегеѕёѕ$: животные, коллекционные карточки, геопоиск 
ѕеекіпд: Женщина 
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Слишком много лишних Вариантов 


Грег отдает Реджи длинный список вариантов. Не- | 
сколько недель спустя Реджи звонит Грегу и говорит, 
что отего списка нет никакого проку: ни одна из кан- 
дидаток не имеет с ним ничего общего. 


Нельзя полностью 
игнорировать увлечения. 
Должен быть другой, лучший 
способ... 


Текушие дела 


Ио 5апИосӘл Надоела: бада олды, 

УЫ оџС то стол цу тер Нион ел, ДД 
использовать ИКЁ/Но ибо. ра . ААТА а Вроде &ужно 
А/будущем как нибудь (обоя 

) ц ы НЫ. 
Я 4 1 Да бб й дерстолбца 3 увлечения ВАЖ 


Прове 
р рерять только первое Увлечение, а на остальные 
не одращать внимания. 


ная информация: 


Использовать тольКо первое увлечение 


Теперь Грег знает, что игнорировать все увлечения нельзя. Он предпо- 
лагает, что люди перечисляют увлечения в порядке важности, и реша- 
ет, что он будет проверять только первое из них. Запросы по-прежнему 
остаются сложными, но не настолько, как при включении ГТКЕ для 
всех увлечений из столбца іпіегезѕі з. 


«.ВОЗЬНИ в руку карандаш 
Б.“ ; Используйте функцию ЗОВЗТВТМС ІМРЕХ для выделения 
< первого увлечения из столбца іпіегеѕіѕ. 
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их нельзя игнор“ 
оваиль, эи^о ИЕН 7 


возьми в руку карандаш. решение 


„ Возьми в руку карандаш 
Ч Решение Используйте функцию ЅОВ5ТКІМС _ТМОЕХ для выделения 


к. первого увлечения из столбца іпёегеѕіёѕ. 


ЅОВЅТЕІМС 1МРЕХ(імфекеѕіб, '/, 1) | | 
«1.» для поиска первой запяилой. 


ыа. 57 С ларамемром <2.> функция выде ~ 


ой за- 
Вызов функции выделяеил все Искомый сим ЛЛА бы все символы до а уб 
символы, предиесилвуюлие вол — заияилая. ИЯИЛОЙ, ИЛО ес илексил пер 
заляилой 6 силолбие <<чифегея5». увлечений. 


Затем Грег пишет запрос, который поможет Реджи найти свою 
пару. В запросе используется функция 50В5ТКІМС ІМРЕХ, 
а первым увлечением должны быть 'животные'. 


ЗЕБЕСТ * ЕВОМ ту сопфас®5 
ИНЕКЕ депаег = 'Ж' В запросах будцил оплоб- 
АМО ѕёаіиџѕ = 'Не замужем' ражаилься илолько жен- 


АМЮ зфафе='МА' щины, у коилорых в сиц ~ 
ске увлечений на первом 


АМО ѕеекіпд ІІКЕ '%Мужчина%' месиле силояил ‘живоилные’ 
АМО ЬігҰҺдау > '1950-28-08' ет 
АМО Ь1гЕРаау < '1960-28-08' 


АМО ЗОВЗТВТМС _ТМОЕХ (іпіегеѕіѕ,',',1) = 'животные'; 


Пара для Реджи 
Наконец-то! Грег нашел пару для Реджи: 


сопёасё 14: 459 

Іаѕі пате: Фергюсон 

Ғігѕі пате: Алексис 

рһопе: 5550983476 

ета11: а1Іехапде1йуаһоо. сот 

депдег: Ж 

Ьігёћаау: 1956-19-09 < подходи 
ргоѓезѕззіоп: Художник 

сіёу: Пфлюгервиль к. _ 

зЕафе: МА живеил близко 
ѕзіаіиѕ: Не замужем 

іпёегеѕзізѕз: животные <—— Йоко 
ѕеекіпд: Мужчина ооящие Увлечения 
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Трагическое несоответствие 


Реджи договорился с Алексис о свидании, и Грег с нетерпением 
ждал его рассказа. Он уже начал представлять себе новую таблицу 
ту сопӯасізѕ, которая станет началом новой социальной сети. 


|[а следующий день Ч двери [Грега строитр ежа — Ч притом очень 
сердитрый. 


ДРЈ 
| еджи крччитр: «Қнечно, она интрересуетрся ЖичВотрнымч, 1А ры 


не сказал Мне, Чтро она деЛаетр чз них чучела! Там повсюду МертрВые 


на 


Текущие дела 


Написать запрос/для Нааджела: А блем и 
паи оенто стобёцу неее Чон И 
использовать ИКЁ'но на один раз сбйдем И р В илаб. ӧ 
АВ/будущем нак нибудь обой 1 «деалоная пара 
А А) ) 24 | 7; дерктолбца м для Реджи, С 
иет. но Грег не нашел 
её, поилому чило 
ее увлечения пере- 
числялись 86 дру - 
гом порядке. 


ПроВврйть только вов ве У Г дд л 
9, | ечен $ а Р ЛА 2 я 
рашат фицкакия /) ИР | у Иа’чейаеныве 5. 


Создать несколько столбцов Эля хранения убле- 


чений, потому что хранение Всех увлечений Ё одном столбце 

усложняет запросы. Грег решаем 
изменииль 

силрукилуру 

своей илаблицы!. 


СХ: 


2 мозговой 
е ШТУРМ 


Как будет выглядеть следующий запрос 
Грега после создания нескольких столб- 


цов увлечений? 
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создание четырех столбцов пиегезт 


Создание новых столбцов іпегесі 


Грег понимает, что с одним столбцом увлчений написать пра- 
ВИЛЬНЫЙ запрос слишком сложно. Приходится использовать 
.ТКЕ, что иногда приводит к неверным совпадениям. 


Но Грег умеет пользоваться командой АГТЕК для изменения 
таблиц, а также разбивать текстовые строки, поэтому он решает 
создать несколько столбцов с увлечениями и поместить каждое 
увлечение в отдельный столбец. Он решает, что четырех столб- 
цов будет достаточно. 


_ Возьми в руку карандаш 
ее Используя команду АТТЕВ и функцию 5ОВ5ТВТМС ІМРЕХ, 
у измените таблицу так, чтобы таблица состояла из перечислен- 
= ных столбцов. Количество запросов не ограничивается. 


сопіёасі іа 
Іаѕє пате 
Ғіүзе пате 
рһопе 
ета11 
депаег 
Ь1кгЕраау 
ргоҒеѕѕіоп 
сіу 

зіаёе 
ѕіаёсиѕ 
іпіёегеѕі1 
іпіегеѕіё2 
іпёегеѕіЗ 
іпёегеѕі4 
ѕеекіпд 


* (зъветы на с, ЗП. 
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Начинаем заново 


Грег чувствует себя виноватым за неудачу Реджи и решает попробо- 
вать еще раз. Для начала он извлекает из таблицы запись Реджи: 


сопёасі іа: 872 

Іаѕё пате: Салливан 

Ғігѕ пате: Реджи 

рһопе: 5554531122 

етаі1: гедіѕӣ@ каһіе]1ееіѕа#1аке. сот 
депаег: Ж 

рігіҺаау: 1955-20-03 

ргоѓеѕѕіоп: Комик 

сіу: Кембридж 


ѕіаіе: МА 

ѕїасиѕ: Не женат = 

іпіегеѕї1: животные | В измененной иладлиие инфор- 
іпіегеѕї2: коллекционные карточки у мация об увлечениях храниился 
іпіегеѕї3: геопоиск А о чеилырех силолбиах. 


іпёегеѕі4: МО 
зеек1па: Женщина 


Грег пишет запрос, который должен вернуть Реджи подходящую пару. Он начинает с про- 
стых столбцов — депаег, зкакиз, ѕќаѓе, зееК1пд ирігећаау — и только потом берется 
пражнение за столбцы ілёегеѕі. 


Запишите его запрос. 
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упражнение. решение 


пражнение 
Ремение 


322 


Грег пишет запрос, который должен вернуть Реджи подходящую пару. Он начинает с про- 


за столбцы 1птегез+. 
Запишите его запрос. 


ЅЕІЕСТ * ЕКОМ илу_соифас $ 


М/НЕКЕ демдер = Ж 

АМР ѕёаћиѕ = ‘Не замужем‘ 
АМР ѕёаёе=МА! 

АМР ѕеекімад ШКЕ Мужчина?! 
АМР бікЕлдау > '1950-20-ОЗ' 
АМР бтердау < ‘1960-20-05 
АМР 

( 

ілЁекеѕ1 = ‘живоимлные' 

ОК імекеѕЕ2. = ‘животные! 

ОК ілъекеѕЕ5 = ‘живоилные! 

ОВ ілёегеѕЕ4 = ‘животные! 


) 
АМ” 


( 


ифеге$ё1 = ‘коллекционные карилочки' 
ОБ. пифегеб2. = ‘коллекционные карилочки' 


стых столбцов — депдег, ѕќасиѕ, збаѓе, зеек1пд и рігіћаау — и только потом берется 


Реджи ищеил незамуж- 
нюю женщину, родив- 
муюся в заданный период 
времени, коилорая живеил 
6 Массачусеилсе и хочеил 
всилречаться с нежена- 
мым мужчиной. 


гы 


Чилобы найили совладе - 
ыы ния с чвлечениями Реджи, 
Грег вынужден прове - 
рииль все чеилыре но- 
ний вых силолбиа <чибегез», 
лоилому чило в каждом 
из них можеил найилисе 


ОК еге$5 = ‘коллекционные карилочки' = совладение. 


ОБ. лфеге$ё4 = ‘коллекционные карилочки‘ 


) 
АМР 


( 

|ибегезЕт = ‘геолоиск! 
ОК імЁекеѕЕ2 = ‘геолоиск! 
ОВ (л+екеѕЕ5 = ‘геопоиск' 
ОК леге$ЕА = ‘геомоиск! 


); 
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е, Силолбец «іиересъду 


Ч Реджи содержиил 
МОЕ, иоэтоми иро- 
беряюился илолько 
ири увлечения Вме_ 
Сило чемлырех. 


многотабличные базы данных 


Все без толку... 


Добавление новых 
столбцов никак не по- 
могло решить основ- 
ную проблему: структу- 
ра таблицы усложняет 
написание запросов к 
ней. Обратите внима- 
ние: в каждой версии 
таблицы нарушается 
правило атомарности 
данных. 


К.азалосе бы, 
илакое хоро 
емление.-- 
Но с НИМ 347 
„росе! силали 


еле сложнее. 


идее 


Текушие дела 


Написать Запро ) 

для! у%аідбс одлжен бі 
йур, И, Ме 64 У м УТА 
испоќьзофать И НО вй раз Арун дса РРА 


РОД ДУ) Нани и деустомца 21 


УВииак / 


> ря" Иесколько см молдова фаненвА ФВле- 


"нений, покору Чую И 
сек емен 
уббфниев вакйобы, ИД Д Нее вони Ве 


е: 


тн у В р ИР айа феде 051 


...Один момент! 


А если создать отдельную таблицу, 
в которой хранится только информа- 
ция об увлечениях? 


мозговой 


0 


Сх 


ШТУРМ 


Какую пользу принесет создание новой таблицы? 
И как связать данные из новой таблицы с существу- 


ющей таблицей? 
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создание дополнительных табл 


Одной таблицы недостаточно 


Итак, если мы будем ограничиваться работой с текущей табли- 
цей, хорошего решения не существует. Мы пытались обойти не- 
достатки структуры данных разными способами, даже изменяя 
структуру всей таблицы. Ни один способ не сработал. 


Рамки одной таблицы оказались слишком узкими. В действи- 
тельности нам нужны дополнительные таблицы, которые 
работают в сочетании с текущей таблицей, позволяя нам свя- 
зать одного человека с несколькими увлечениями. При этом 
существующие данные будут полностью сохранены. 


Неатомарные столбцы из существующей 
таблицы следует переместить в новые 
таблицы. 


ЕПе Ечи У/ипаом Нер МеззуТаЫе 
> РЕЗСВТВЕ ту сопбасіѕ; 


РеЕаз1 + ЕхЕга 


| 
2 


сопёас+ іа ацџіо іпсгетепё 


1азЕ пате уагсћһахг (30) 


Ғігѕё пате 
рһопе 
етаі1 
депаег 
Ьігёһаау 
ргоЁеѕѕіоп 
сіу 

зфафе 
ѕъаёиѕ 
іпёегеѕіѕ 


уагсћаг (20) 
уагсћҺаг (10) 
уагсћах (50) 
сћаг (1) 

дае 

уагсћһаг (50) 
уагсћаг (50) 
уагсрахг (2) 
уагсћһћаг (20) 
уагсћаг (100) 
уагсҺаг (100) 


13 комѕ іп ѕеё (0.01 ѕес) > 


многотабличные базы данных 


Многотабличная база данных с информацией о Клоунах 


Помните нашу таблицу с информацией о клоунах из главы 3? 
Проблем с клоунами становится все больше, поэтому мы 


преобразовали одну таблицу в более удобный набор из не- Так выглядела силарая 
скольких таблиц. иладлица сі оии_Егасктиа. 
сІомп Сгаскіпӯ 
[себе | 


Ж, рыжие волосы, зеленый костюм. 


Элси Дом престарелых Черри 
хилл 


Пиклз Вечеринка Джека Грина 


ботинки 


ранжевые в ы, синий 


ботинки 


Снаглз ь 
МАО Иру р ур. 


Болмарт 


Ей 


Скоро вы поймете, 
Чило означаюил эили 
линии со силрелкалии... 


асііуіќу 14 


Іосайоп і Ор 


мозговой 
ШТУРМ 


Как вы думаете, что означают линии 


На нескольких ближайших 
страницах мы покажем, почему 
таблица была разбита именно так, 
а не иначе и что означают все эти 
стрелки и ключи. А после этого 
вы сможете по тем же принципам 
разбить таблицу Грега. 


со стрелками? А изображения ключей? 
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построение схемы базы данных 


Схема базы данных еомп_#гаеКіпо р 
иларая 


Представление всех структур базы дан- | И" иладлица. 
ных (таблиц, столбцов и т. д.) и логи- сТома_хаскапа 


ческих связей между ними называется а 
и л Дом престарелых Черри } Ж, рыжие волосы, зеленый костюм, | шарики, машинки 
схемои. И Хи огромные ботинки 


Вечеринка Джек и М.М, оранж во) иний мим 


костюм, огромные богинки 


Наглядное представление базы данных ЕЕ: з т ТТЕ 
поможет вам представить, как связаны х АД | з Ату рас, А Оина рә 
между собой компоненты базы данных, 

однако схема также может быть записа- 

на и ввиде текста. 


Го мило осилалось 
оил силарои 
илаблице!. 


Осилальные Силолдиы сила 
илаблииы сі 


Выделены в 


ой 
Оми _Ёғаскіла были 
оилдельные илаблицы. 


АВЕ „РЕЯ 


Іосайоп іа ОР 


іпѓо Іоса?іоп 
р 
Іосайоп_іа ур 


мпеп 


Описание данных (столбцов и таблиц) 
вашей базы данных, включая все взаи- 
моевязанные объекты и связи между 
ними, называется СХЕМОЙ. 
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многотабличные базы данных 


Упрощенное представление таблиц 


Вы видели, как была преобразована таблица с информацией о клоунах. 
Теперь давайте попробуем сделать то же самое с таблицей ту сопіасі5. 


До настоящего момента мы либо схематично изображали таблицы с име- 
нами столбцов в заголовках и данными внизу, либо выводили их описание 
в окне терминала командой РЕЗСВТВЕ. Оба способа хорошо подходят для 
отдельных таблиц, но когда требуется построить диаграмму из нескольких 
таблиц, приходится искать что-то другое. 


Ниже показано упрощенное представление таблицы ту сопѓасіѕ. 


Означаеил, чило 
= силолбец являемся 
первичным ключом. 


сотасі 19 т © 


8 орядке их следо 
<— вания 6 илаблиие 


Диаграмма помогает отде- 
лить структуру таблицы 

/ от хранящихся в ней 
данных. 
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разбиение таблицы 


Как из одной таблицы сделать 98е 


Мы знаем, что написать запрос для поиска информации в столбце 
іпсегезіѕ в его текущем виде довольно затруднительно, потому 
что в одном столбце могут храниться сразу несколько значений. 
Впрочем, создание нескольких раздельных столбцов не особенно 
упростило нашу задачу. 


Справа изображена таблица пу сопѓёасіѕ в ее текущем состоя- 
нии. Столбец іпіегеѕіѕ не атомарен, и существует только один 
действительно хороший способ сделать его атомарным: нам пона- 
добится новая таблица, в которой будут храниться все увлечения. 


Для начала нарисуем несколько диаграмм, которые покажут, как 
будут выглядеть новые таблицы. Только после того как будет гото- 
ва новая схема, можно будет переходить к созданию новых таблиц 
или модификации данных. 


1) Удаляем столбец іпќегеѕќѕ и размещаем 
его в отдельной таблице. 


Столбец іпіегеѕіѕ перемещается в новую таблицу. 


сотіасї 18 


р 


оїеѕѕіоп 


зеекта 


В новой таблице іпбегеѕіѕ будут храниться 
все увлечения из таблицы ту _сопфасе$ (от- 
дельная запись для каждого увлечения). 
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| ту _сопўас?в | 

Таблица и^у_ 
сом+ас+ѕ еще 
ам 
к, 
Пааа 


Добавление поля 
і4 гаранилируеил, 
чило В илаблиие 


—— не будем дубли - 


каилоб. 


Силолбец <илфегезЕ» 
улила МАВСНАЕ содер - 
жиил факилическое оп” 
сание увлечения. В нём 
храняился силроки вида 
‘улуризм' или ‘кчлина- 
рия". 


многотабличные базы данных 


Добавляем столбцы, по которым можно будет 
узнать, какие увлечения принадлежат тому или 
иному человеку из таблицы ту _сопќасѓѕ. 


Мы вынесли увлечения из таблицы му сопбасізѕ, но как 
определить, кому какие увлечения принадлежат. Необходимо 
использовать информацию из таблицы ту сопеасез и раз- 
местить ее в таблице іпбегеѕіѕ так, чтобы эти две таблицы 
были связаны между собой. 


Например, для этого можно включить столбцы Ёігзэс пате 
и Іаѕі пате В таблицу іпіегеѕіѕ. 


| Лавеғевїз_| По эмлим двум силолд - 
цам можно узнаиле, 
кило какими чвлече- 
ниями обладаеил. 

Е } =—— 


[а${_ пате 


Если эили значения совладаюил 
значиил, человек обладаеил | 
данным увлечением. Тадлииа 
‘ифегезЁ$ содержиил несколько 
записей с совладением эилих 
значений, чило позволяеил 
сбязаиль с одним человеком 
сразу несколько увлечений. 


125.мозговой 
С УШТУРМ 
Мы двигаемся в верном направлении, но #ігѕї пате 


и 1азЕ пате — не лучшие столбцы для связывания 
таблиц. 


Почему? 


Запьше » 
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добавление связей на диаграмме 


СВязывВание таблиц на диаграммах 


К таблице му_сопфас®$ стоит присмо- 
треться повнимательнее. 


Вот ее исходный вариант. 


таблица иЧегея: 


канд зата 
а 
от 
[аЯ пате - 
таблица ту _ софа ифегеяр 
(беъ ЙЕ іиќегеѕ15) 4 


ываюился ис совиа- 

олбцах «Вибе плате” 
Совладения опре- 
кими увлечения” 


Таблицы связ 
дениям В сил 
и <(а5_маиле?”. 
деляноил, кило Ка 
ми обладаем. 


Обратите внимание на линии между таблицами: они 
обозначают столбцы с совпадающими значениями. 
Диаграмма, представленная в таком виде, будет по- 
нятна для любого ЗОГ-разработчика, потому что 

в ней используются стандартные обозначения. 


А вот как выглядит серия команд ЗЕТЕСТ, которая 
позволит нам использовать данные из обеих таблиц. 
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ЗЕБЕСТ Ғігѕё пате, 1Іаѕё пате 
ыы = 

ЕВОМ ту сопёасіѕ 

МНЕВЕ (условия); 


С 


Вам кажеилс 
И иравилено- 
лользоваиле данны 
данных из другой ила 
как сделаиле ило же сам 


Она всего лиш 
е одной ила 


330 


глава ? 


А вот как выглядит новая схема. 


іт 90 | 


#51 пате 


( 


Линиями обозначаюил - 
ся совпадения в данных. 
Линии не обязаилельно 

ироводииль под прямым 


9глом, но илак их проше 
отслеживаиль. 


ЗЕІЕСТ 1п6егезЕ РГАОМ 1пеегез*з 
ИНЕВЕ Ғігзе пате = 'Имя' 
Аи Іазі пате = 'Фамилия'; 


2 
я, чило эила запись неэффекиливна: | 
| ь иоказываеил, как ис 


блииы для извлечения 
блицы. (Вскоре мы покажем, 
ое более эффекиливно.) 


многотабличные базы данных 
г. Возьми в руку карандаш 


Какие еще таблицы стоит добавить в базу данных дгедз_11$% 
для хранения информации о нескольких увлечениях? 


а. 


Не старайтесь нарисовать аккуратную схему; сейчас время со- 
бирать идеи. Одна идея уже изображена на рисунке, но у нее 
есть недостаток. 


ы 


таблица іїегеѕі5: 
каждая запись 
содержит: 

[91 мате 

[а$ пате. 
Таблица ту софа іиїеуеѕ/ 

(без столдца ифеге 5) 


Вла ~ 
Таблице! связывањюился Ио е 
дениям 6 силолбиах «ЁЁ и * 
и <<1а5Ё маиле? Совладения опр 


Е - 
Эеляюмл, кило какими увлечени 
ми обладаем“. 
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возьми в руку карандаш. решение 


«_ Возьми в руку карандаш 
| Решение Какие еще таблицы стоит добавить в базу данных дгедз_ 1іѕі 
Қ. для хранения информации о нескольких увлечениях? 

Не старайтесь нарисовать аккуратную схему; сейчас время со- 
бирать идеи. Одна идея уже изображена на рисунке, но у нее 
есть недостаток. 

рый о связывание илаблиц ио имени 

и Фамил — У, № 
Таблица ийегея5: В списке Е не самый лучший способ 
каждая запись 9-сол+асіѕ мМогуил оказаиль- 


ся д 
содержит: 

грн 
([аЯ пате 
тагї 


анные людей с одинаковым именем 
и фамилией, в резульилате чего можеил 
бозникнуиль иуиланица с убвлечениями 
Лучше использоваиль для связывания 
иладлиц первичный клюц. 


д 
таблицы связываюился ио сови А 


[ улё> 
биах «Низ а 
иям 6 силол 22 
Е Диле? Совладения оир 


ия- 
деляюил, КИЛО какими увлечен 
ми обладаем. 


Таблица ту _сотїасіѕ 
(без столдца и\еге 5) 


Вмесило илого, чилобы ислользоваиль «Вис маиле» 
и «<Їаѕ мамле», коилорые могцил оказаилося 

не уникальными, для связывания илаблиц 

лучиле Взяиль «сомЁасЁ >: 


илаблииа 
(лфеге$Еб: 
каждая запись 
содержиил те 
ГАБЕГЕЗЕ 
соибасе 14 


илаблица 


ен Силолдец «сомёас+ ід» со- 
(дез силолдиа де 55 
<««ілЕегеѕёѕ») Ржиил заведомо уникаль - 


ные значения. Мы можем 
быиль илвердо уверены в илом, 
чило увлечения с неколорым 
«с0лЁасЕ 14» принадлежаил 
сооилвеилсилвуношщей записи 

из илаблицы «‹илу сои+асіс». 
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Связывание таблиц 


У первой версии связанных таблиц был один серьезный не- 
достаток: мы пытались использовать для связывания поля 
Ғігѕі пате и 1аз® пате. А если в таблице ту сопбасїзѕ 
появятся записи с одинаковыми значениями ЃЁігзі пате 
и1]азЕ папе? 


таблица ифекеЯ 5: 
каждая запись 
содержит: 
р пате 
[аЯ пате К. 
іиеғеѕї 


таблица ту _сокїасіѕ 
(без столбца ищеге$ $) 


Две таблицы должны связываться через уникальный стол- 
бец. К счастью, поскольку мы уже занялись нормализацией, 
вту сопёасіѕ такой столбец уже имеется: это первичный 
ключ. 


Мы можем хранить значения первичного ключа из таблицы 
пу сопёасіёѕ в таблице іпбегеѕіѕ. И что еще лучше, по 
этому столбцу можно будет определить, какие увлечения при- 
надлежат тому или иному человеку из таблицы ту сопѓёасіз. 
Такой способ связывания называется внешним ключом. 


0а новая иладлица сооил - 

аи правилам первой 
РМальной формы, каждой 

Записи назначаеился Чникаль - 


ное зна 
чение первичного клюцд. 


и 
ВНЕШНИЙ КЛЮЧ 
оиределяеил, какие 

увлечения принадле - 

жаил илому или ино- 


мч человеку из илад- 
лиць илу_сомЁасіѕ. 


сопїасї 1а О 


многотабличные базы данных 


Если у двух людей зна - 
чения полей Е иаиле 
и [а паиле совладаноил 


М0 их инилересы лере - 
иумаюился! 


ВНЕШНИЙ КЛЮЧ — 
столбец таблицы, 


в котором хранятея 
значения ПЕРВИЧ- 
НОГО КЛЮЧА 


другой таблицы. 
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знакомство с внеинчими ключами 


Что нужно знать о Внешних Ключах 


Имя внешнего ключа может отличаться 
от имени первичного ключа, с которым 
он связывается. 


Первичный ключ, используемый внешним ключом, также 
называется родительским ключом. Таблица, которой 
принадлежит первичный ключ, называется родительской 
таблицей. 


Внешний ключ может использоваться для установления 


соответствия между записями двух таблиц. 


Внешний ключ может содержать значения МИЦ, хотя 
в первичном ключе они запрещены. 


Значения внешнего ключа не обязаны быть 
уникальными — более того, чаще они уникальными 
не являются. 


Понимаю, внешний ключ 
позволит мне связать две таблицы. Но какой 
прок от значений МОИ. во внешнем ключе? 
Можно ли сделать так, чтобы внешний ключ всегда 
был связан с родительским ключом? 


Значение МОШ во внешнем ключе 
означает, что в родительской таблице 
не существует соответствующего 
значения первичного ключа. 

Однако мы можем сделать так, чтобы внешний 
ключ принимал только осмысленные значения, 


существующие в родительской таблице. Для это- 
го следует воспользоваться ограничением. 
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Ограничение Внешнего Ключа 


Хотя вы можете создать таблицу со столбцом, который 
будет выполнять функции внешнего ключа, такой стол- 
бец действительно станет внешним ключом только в том 
случае, если вы назначите его таковым в команде СВЕАТЕ 
или АГТЕВ. Ключ создается в структуре, называемой 


ограничением. 


Хе Ограничение — Эрл сао | 
правило, коилорое должно БОА 


наилься илаблицей. 


При вставке внешний ключ будет принимать 
только значения, существующие в первичном 
ключе родительской таблицы. Это требование 
называется целостностью данных. 


Исходная илаблица илц сотъасіѕ сила - 
ла родиилельской иладлицей, поиломи 


ў. чило часиль ее данных была переме - 


иёна 6 новую илаблииц, называемую... 


сопїасі іа бе 


„дочерней 
С млаблицёй. 


сопїасї_ іа р |<— 
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Создание ВНЕШНЕГО 
КЛЮЧА как ограни- 
чения таблицы дает 
определенные преиму- 
щества. 


При попытке наруше- 
ния правила вы полу- 
чите сообщение об 
ошибке; таким образом 
предотвращаютея елу- 
чайные нарушения евя- 
зей между таблицами. 


Термин <<целосилносиль данных» 
означаеил, чило во внешнем ключе 
дочерней илаблицы могуил со- 
храняилься илолько иле значения. 
коилорые уже суиесилвуюил 

0 родиилельской илаблиие. 


Внешний ключ должен быть связан с уникальным 
значением из родительской таблицы. 
ан 


Это значение может и не быть значением 
первичного ключа, но оно обязательно должно 


быть уникальным. 
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зачем нужны внешние ключи 


Стоит ли Возиться с Внешними Ключами? 


Итак, упростить получение информации об 
увлечениях можно только одним способом: убрав 
их из таблицы ту _сопїасїѕ. И Реджи нужно по- 
добрать нормальную пару... Осталось понять, КАК 
создать таблицу с внешним ключом. 


Внешний ключ можно назначить 
при создании таблицы. 


Внешние ключи также можно добавлять при 
выполнении команды АГТЕК ТАВІЕ. Синтак- 
сис прост, но вы должны знать имя первич- 
ного ключа в родительской таблице, а также 
имя родительской таблицы. Давайте созда- 
дим таблицу 1п%егез& $ с внешним ключом 
сопфас®_14 из таблицы му _сопас*$. 


Часто 
Задаваемые 
Вопњсы 


‚ Как написать запрос на выборку увлечений после того, как они будут из- 
влечены из шү сопбасіз? 


() Этим мы займемся в следующей главе. И вы увидите, что написать запрос на 
выборку данных из нескольких таблиц не так уж сложно. А пока необходимо изме- 
нить структуру ту сопіасіѕ, чтобы запросы были простыми и эффективными. 
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Создание таблицы е Внешним Ключом 


Теперь вы знаете, зачем создаются внешние ключи, 
и мы можем перейти непосредственно к способу их 
создания. Обратите внимание на имя, назначенное 
ограничению (СОМЅТКАІМТ): по нему можно легко 
определить, из какой таблицы берется ключ. 


Включение команды РЕІМАЌҮ 
КЕҮ 6 силрокц с определением — 
другой (более дысилрый) способ 


СВЕАТЕ ТАВІЕ іпёегезёз ( назначения первичного ключа. 


}. 


іпс іа ІМТ МОТ МОЛ, АОТО ІМСКЕМЕМТ РВТМАВУ КЕУ, 


Ограничению присваивается имя, 
іпіегезі УАВСНАВ (50) МОТ МОШ., ио коилорому можно определииль, 
из какой илаблицы взяил — 
> мот (илу_соифас®$), как он назыбаеился 
СФЕРтНЕ РОРЕРрОЦТ ыы сомбасЕ 2) и чило ключ являеился 
Внешний внешним (ЁК). 
ключ созда- СОМЗТВАТМТ шу сопасев ‘сопеасЕ арек ^ Если позднее мы за- 


бился илоч- н изменииль 
но мак же, свое рещение, ил 

о а 2 о 
как любой ГОВЕТСМ КЕУ (сопёасё іа) Өл =, использцем эүло имя. 
индексный 


Силрого говоря, эила 


силолбеи: ВЕРЕВЕМСЕЗ щу сопёасёѕ (сопбасё ій); | срока не обяза- 


с иипом илельна, но ее р 
еко- 
данных ІМТ (Ы У мендцеился вВключаиль 
и о Указываеил, из ка- КЕР Ег Пас 6 команду. 
. Я зы У] 
мо кой иладлицы взяил ОИ В кода указываеился 


У иладлице. 
Внешний ключ... яе имя Внеинего ключа. Вы 


можеиле назваило его улак, 
как сочилеиле нужным. 


А теперь попробуйте сами. Откройте окно консоли и введите приведенный 
выше код создания таблицы 1пеегез{ 5. 
пражнение РВ В 


Когда таблица будет создана, просмотрите описание ее структуры. Какая новая 
информация в описании сообщает о наличии ограничения? 
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упражнение. решение 


пражнение 


Ее Еак У/ипаом Нер 


> ОЕЗС 1пеегезфз; 


: Зачем столько хлопот с созданием 
ограничения внешнего ключа? Разве 
нельзя использовать ключ из другой 
таблицы в качестве внешнего ключа 
без создания ограничения? 


() Можно, но при создании ограниче- 
ния в таблицу будут вставляться только 
значения, уже существующие в родитель- 
ской таблице. Ограничение гарантирует 
корректность связи между таблицами. 


О 
• «Гарантирует корректность свя- 
зи»? Что это значит? 


() Ограничение внешнего ключа обе- 
спечивает целостность данных (иначе 
говоря, оно следит за тем, чтобы запись 
с внешним ключом в одной таблице 
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А теперь попробуйте сами. Откройте окно консоли и введите приведенный выше код 
создания таблицы іпіегеѕіз. 


Когда таблица будет создана, просмотрите описание ее структуры. Какая новая инфор- 
мация в описании сообщает о наличии ограничения? 


«МОГ» означаеил, чило одно значение можеил храниться 6 силолдие 
6 нескольких экземилярах. Этлоил факил позволяет нам хранииль несколь- 
ко увлечений для каждого значения соиёась (А из илаблииы илу_сопфасЕе. 


Частро 


адаВаеМые 
Вопсьы 


всегда имела соответствующую запись 
в другой таблице). Если вы попытаетесь 
удалить запись в таблице с первичным 
ключом или изменить значение первич- 
ного ключа, задействованного в ограни- 
чении внешнего ключа другой таблицы, 
будет выдано сообщение об ошибке. 


: Выходит, что я никогда не смогу 
удалить из шу сопфасе$ запись с 
первичным ключом, который при- 
сутствует в таблице іпбегеѕ+ѕ в каче- 
стве внешнего ключа? 


() Сможете, но сначала придется 
удалить запись внешнего ключа. В кон- 
це концов, если вы удаляете запись из 
ту сопіасіз, знать увлечения этого 
человека вам уже не обязательно. 


; А почему нельзя просто оставить 
эти записи в таблице іпіегеѕзіз? 


() Они снижают эффективность работы 
с данными. Со временем такие записи 
накапливаются, и обработка запросов 
замедляется из-за необходимости поиска 
в бесполезной информации. 


В: Ладно, убедили. Какие еще бывают 
ограничения? 


(); Вы уже видели ограничение первич- 
ного ключа. Ключевое слово ОМІООЕ 
(при создании столбца) тоже считается 
ограничением. Также существует огра- 
ничение СНЕСК, не поддерживаемое 

в МуЗСЕ. В нем можно задать условие, 
которое должно выполняться для вставки 
значения в столбец. За дополнительной 
информацией о СНЕСК обращайтесь 

к документации своей РСУБД. 
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СВязи между таблицами 


Итак, вы знаете, как связать таблицы через внешний ключ, но мы по- 
прежнему должны разобраться в сути связей между таблицами. В табли- 
це пу сопіасіёѕ проблема заключается в том, что многих людей нуж- 
но связать с многими интересами. 


Это один из трех возможных типов связей, которые постоянно встре- 
чаются при работе с данными: «один-к-одному», «один-ко-многим» и 
«многие-ко-многим». Когда вы знаете, к какому типу относятся ваши 
данные, разработка структуры из нескольких таблиц (то есть схемы) 
становится достаточно простым делом. 


Типы связей: «один-К-одному» 


Начнем с первого типа, «один-к-одному», и посмо- 
трим, как он применяется на практике. В связях 
этого типа запись из таблицы А может быть связана 


0 Таблица А 
НЕ БОЛЕЕ ЧЕМ С ОДНОИ записью в таблице В. 


Допустим, в таблице А хранится ваше имя, а в табли- 
це В — информация о доходах и номера социального 


страхования (такая изоляция повышает безопасность 7———— ввязывается 
данных). РОВНО ОДНА —— 0 РОВНО ОДНОЙ 
В обеих таблицах присутствует поле епр1оуее іа. цз этих записей из этих записей 


Поле епр1оуее_14 родительской таблицы является 
первичным ключом, а поле етр1оуее іа дочерней 
таблицы — внешним ключом. 


В схеме такая связь обозначается простой соедини- 
тельной линией. 


И человека 6 илаблице емлріоцееѕ можеил быль илолеко 
один номер социального силрахования, а каждый номер можеил 


А принадлежаиль илолько одному человеку. Следоваилельно, дан - 


ная сбязь омлносиился к илипу «один -к-одному>». 


епр1оуеез и ѕа1агу 


| Бейонс | Ноулз РТА: |ы зао Пн АДА 
345678912 
ЕЕ е: осо Е вен ТЕЕ 0] 


т. Эили илаблицы иложе связаны оилношением РЕН ий т 
илак как первичный ключ илаблицы вил оцее (илр ней аре. 
использцеился 6 качесилве внешнего ключа илаблицы за[аиу. 
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связи типа «один-к-одному» 


Когда используютея таблицы со связями 
типа «один-К-одному» 


Выходит, все данные, 
со связями «один-к-одному» 
следует выделять в новые 
таблицы? 


Вообще-то нет. Таблицы со связями «один- 
к-одному» используются не так уж часто. 


Есть несколько причин для установления связей 
типа «один-к-одному» между таблицами. 


Когда используются сВязи типа «один-К-обному» 


Обычно данные, связанные по типу «один-к-одному», разумнее 
хранить в основной таблице, однако выделение их в отдельную 
таблицу иногда приносит некоторые преимущества. 


1. Выделение данных может ускорить обработку запросов. 
Например, если подавляющее большинство запросов из- 
влекает только номер социального страхования и ничего 
более, лучше обращаться с запросом к меньшей таблице. 


2. Если столбец может содержать неизвестные на данный 
момент значения, выделение его в отдельную таблицу по- 
зволит избежать хранения МОГ, в основной таблице. 


3. Изоляция части данных помогает ограничить доступ к ним. 
Например, если у вас имеется таблица с записями работ- 
ников, информацию о доходах лучше хранить отдельно от 
основной таблицы. 


4. Большие блоки данных (например, тип ВІОВ) тоже лучше 
хранить в отдельной таблице. 


«Один-к-одному»: ровно одна запись 
родительской таблицы связывается 
е одной записью дочерней таблицы. 
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Типы связей: «один-Ко-многим» 


В связях типа «один-ко-многим» запись в таблице мо- 
жет быть связана со многими записями в таблице В, 
но каждая запись в таблице В может быть связана 
только с одной записью в таблице А. 


Одна запись в илаб- 
лице А может 
быиль связана со 
МНОГИМИ заии- 
сями 6 иладлице В, 
но любая запись 

6 иладлице В мо- 


Р 7а А Таблица В 


связывается 
н жеёил быиль связана 
ОДНА ( МНОГИМИ илолько с ОДНОЙ 
из этих цз этих записью В илаб- 
записей записей лице А. 


Данные о профессии в таблице ту сопбасіѕ 
являются хорошим примером связей типа «один- 
ко-многим». Человек всегда имеет только одну 
профессию, но несколько человек из таблицы 

пу сопёасіз могут иметь одинаковые профессии. 


В этом примере мы вынесли столбец ргоѓеѕѕіоп 
в новую дочернюю таблицу и заменили столбец 
ргоѓеззіоп внешним ключом ргоЕ іа. Для свя- 
зывания таблиц используется столбец роѓ іа, 
присутствующий в обеих таблицах. 


Соединительная линия помечена треугольной 
стрелкой на одном из концов; это означает, что 
одна запись связывается со многими записями. 


Каждая запись таблицы ргоЁез$1оп$ может быть 
связана со многими записями му сопфасез, но 


Так к 
каждая запись му сопбас®$з всегда связана только ак знач 


ргоЁ за От 


ёния рео гд 
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«Один-ко-многим»: 
запись в таблице А 
может быть евязана 
е МНОГИМИ запи- 
еями в таблице В, 
но запись в табли- 
це В может быть 
связана только 

с ОДНОЙ записью 
в таблице А. 


[мну вовне | 
_ 9 55-х 


мог : 
с одной записью в таблице ргоЕе551оп5. аа повллоряџлься 
Силолде ; 
Например, значение рго# іа для профессии Жемил дыиль на уд мо- 
«Программист» может встретиться в ту сопіасізѕ Ключом. Эило им 
несколько раз, но у каждого человека в таблице Ключ, связанный ‘(иний 
пу_сопЕас®е$ может быть указан только один код чом друго С Клю- 


ргоЕЁ іа. 


й иладлицы. 
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СВЯЗИ «многие-хо-многим» 


Типы сВязец: «мно?це-Ко-мно?им» 


Многие женщины держат в своем гардеробе много Е: Таблица В 
пар обуви. Если мы создаем две таблицы с информаци- 
ей о женщинах и марках обуви, то между этими двумя 
таблицами будет существовать связь типа «многие-ко- 
многим», потому что обувь некоторого типа может 
принадлежать многим женщинам. 


связываются 
Предположим, Кэрри и Миранда купили шлепанцы МНОГИЕ —— С 
и туфли «Прада», у Саманты и Миранды есть сандалии, 
ау Шарлотты есть вся эта обувь. Связь между таблица- Б Э 
ми мотеп и зноез будет выглядеть так. записеи записеи 


зһое іа зһое пате 
-— 


МНОГиМи 


ИЗ ЭГТиХ иЗ ЭТИХ 


А теперь представьте, что наши героини купили по 
паре каждой обуви, которой у них нет. В этом случае На обоих концах соедини ея 
связь между таблицами примет следующий вид. линий именился силрелки, ег соя 


а зываем многие записи со многими. 


зһое іа 
с—= 


| 


С мозговой 
ШТУРМ 


Как изменить структуру таблиц без хранения нескольких значений в одном столбце 
(чтобы не столкнуться с теми же проблемами, что и Грег в своих запросах для Реджи)? 
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Возьми в руку карандаш 


чы, Взгляните на первую пару таблиц. Мы попытались ре- 
Ч шить проблему, включая столбец ѕћое 14 в таблицу 


с информацией о женщинах в качестве внешнего ключа. 


Две илаблииы связаны 
через силолдеи «сое ід». 


А теперь изобразите структуру таблиц, но на этот 
раз включите столбец мотап 14 в таблицу ѕћоеѕ 
в качестве внешнего ключа. 


Когда это будет сделано, нарисуйте связи между 
таблицами. 
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возьми в руку карандаш. решение 


«ВОЗЬМИ в руку карандаш 


ещение Взгляните на первую пару таблиц. Мы попытались ре- 
шить проблему, включая столбец 5пое іа в таблицу 
с информацией о женщинах в качестве внешнего ключа. 


мотапт_14 Ох 


авва | зкое ние | 


ПИВНИ 00) «ве 
7 


М, 


Обраили иле внимание т А теперь изобразите структуру таблиц, но на этот 
на дибли камиле! 6 силолди раз включите столбец мотап іа в таблицу зНоез 


јо м | 9 


ож 


й 5 
бе иладлицы связаны 
через силолдец ‹Иое га. 


и 
; 


10 / 


<<«моилаи> и <<с$поё УЧАИЛЁ?. — вкачестве внешнего ключа. 
Когда это будет сделано, нарисуйте связи между 
таблицами. 


зһое іа Ст 


 \Сандалии | / 3з У 
Е ЕН ЕЕ ЕЕ 
[ Шлепанцы У 1 
| Савона 
7 


Туфли «Прада» 


мощ |! 


10 


НН 
| | 
Ҹ 3 
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Нам нужна соединительная таблица 


Как вы только что убедились, включение любого из первичных клю- 
чей другой таблицы в качестве внешнего ключа приводит к дубли- 
рованию данных. Обратите внимание, сколько раз в таблице повто- 
ряются имена женщин. В идеале они должны встречаться в данных 
только один раз. 


Нам понадобится дополнительная таблица, которая свяжет между со- 
бой эти две таблицы и упростит связи «многие-ко-многим» до «один- 
ко-многим». В этой таблице будут храниться все значения иотап_14 
вместе со значениями ѕћое 14. Нам понадобится соединительная 
таблица со значениями первичных ключей двух связываемых таблиц. 


Прямое связывание эилих двух илаблии 
неэффекиливно, иомому Чило из-за 


о сбязей «многие -ко-многим» в данных 
лоябляеился много дубликаилоб. 


| 


Саманта «многце-Ко-мно?им» 
Шарлотта 
Миранда СРИИ 


^ Берем первичный ключ другой первичный 7 
О ИЛОЙ илаблииы. | КЛЮЧ из эилой. . 


си размещаем их в соедини- 
/ илельной иладлиие. 


«один-Ко-многим» 


мотатп_ їе 


«один-Ко-многим» 


В соединиилельной н? 
илаблиие храняился 
первичные ключи двух 
связываемых илаблии. 


«Многие-ко-многим»: 
в соединительной та- 

ое блице хранятея ключи 

с сооилвеилсилвуюшщими б б 

силолдиами соедини - из ооеих та ЛИЦ. 


илельной илаблицы. 


Силолдцы первичных 
КЛЮЧЕЙ одоих исходных 
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подробнее о связях «многие-ко-многим» 


Типы связей: «мнозце-Ко-мнозим» 


Теперь вам известен главный секрет связей «многие-ко-многим»: обычно они состоят 
из двух связей «один-ко-многим», объединенных при помощи соединительной таблицы. 
ОДИН человек из таблицы пу сопіасіѕ связывается со МНОГИМИ увлечениями 
из новой таблицы іпіегезіёз. Но так как каждое увлечение может принадлежать не- 


скольким людям, такая связь относится к типу «многие-ко-многим». 


В соответствии с этой схемой столбец іпіегезіз может быть преобразован в связь 
«многие-ко-многим». У каждого человека может быть несколько увлечений, и каждое 
увлечение может принадлежать нескольким людям: 


Между э 
и Глъсгеѕіѕ, плеере сч 


и 2вимя илаблицам 
А идесилвцеил связь `\ 


«многие-ко -многим»- 


сопіасі іа бе 


: Всегда ли следует создавать 
соединительную таблицу в связях 
типа «многие-ко-многим»? 


(} Да, всегда. Связи «многие-ко-многим» 
между двумя таблицами приводят к воз- 
никновению дубликатов, нарушающих 
требования первой нормальной формы 
(через пару страниц мы напомним, что 
такое нормализация). 


Не существует веских причин в пользу на- 
рушения первой нормальной формы, зато 
доводов «против» предостаточно. Самый 
серьезный из них — сложности с построе- 
нием запросов при наличии дубликатов. 
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один-ко-многим 


сопїасїі 19 Ф 


_ Частро 
адаВаеМые 


Восы 


и какую пользу мне принесет 
такое изменение? Я с таким же успе- 
хом могу разместить все увлечения 
в таблице со столбцами сопбасё іа 
и іпіегезі пате. Конечно, в ней 
будут дубликаты, но в остальном — 
почему бы и нет? 


() Вы поймете преимущества такой 
структуры в следующей главе, когда мы 
начнем строить запросы к связанным 
таблицам с использованием соединений. 
Кроме того, эти преимущества также 
могут зависеть от особенностей исполь- 
зования данных. Может оказаться так, что 
в таблице вас больше интересует именно 
связь «многие-ко-многим», а не данные 

в каждой из связываемых таблиц. 


іпќегеѕї іа Ож 


и, илу_соифаст$ 


один-ко-многим 


В: А если я все равно не против 
дубликатов? 


() Связывание таблиц помогает обе- 
спечить целостность данных. Например, 
если вам потребуется удалить записи из 
ту сопёасїіѕ, изменяется только табли- 
ца сопіасі іпёегезі. Без отдельной 
таблицы вы можете случайно удалить 
лишние записи. Получается, что такая 
структура безопаснее. 


Также упрощается обновление информа- 
ции. Допустим, вы допустили ошибку в 
описании увлечения — например, написа- 
ли «туризъм». Чтобы исправить ее, будет 
достаточно изменить всего одну запись 

в таблице іпёегеѕіѕ, а содержимое 
таблиц сопасі іпёегеѕі иту 
сопіасіѕ останется неизменным. 


многотабличные базы данных 


ЗЫХЗЕОРИЛИ ЗАЛ СЭЗ 


В каждой из представленных ниже таблиц, знакомых вам по предыдущим главам, 
решите, какой тип связи лучше использовать для помеченного столбца — 
«один-ко-многим» или «многие-ко-многим». 


(Не забудьте, что при наличии связи «один-ко-многим» и «многие-ко-многим» 
столбец выделяется из таблицы и связывается через идентификатор.) 


СВЯВЬ 


о? га {та 
0 © в) пис Тура — 


оп їғаскіпа 


сопїасї іа ОР 
_ $ате 


т 


< еге. 


3 


роок іа О 


(ашфог» 
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выберите тип связи. ответ 


ЗЫЗЕРИЛЕ ТАЛ СВЯЗИ 


В каждой из представленных ниже таблиц, знакомых вам по предыдущим главам, реши- 
те, какой тип связи лучше использовать для помеченного столбца — «один-ко-многим» 
или «многие-ко-многим». 


(Не забудьте, что при наличии связи «один-ко-многим» и «многие-ко-многим» столбец 
выделяется из таблицы и связывается через идентификатор.) 


СОА СЕШМ СВЯЗЬ 


© т 77 Е 
Г) «один -ко -Многим» 


сіомп_їгаскіпо 


[дот 190—ж | 
Ие «многие -ко -многим» 


сопїасі іа Ож 
ее | „один -ко многим» 


Вопрос с модвохом: у книги 
можеил быль несколько авило ~ 
ров, поэилому связь оилносиился 
к илиич «многие -ко-Многим». 


«многие-ко-многим>» 


<«один-ко-многим> 
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Исправляем таблицу Грега 


Я понял, к чему вы клони- 
те. Мы преобразуем базу данных 
дгедѕ |і и таблицу ту_сопїасїѕ 
в многотабличную форму, верно? 


Почти. Теперь, когда вы разбираетесь 
в типах связей, мы почти готовы 
к переработке структуры дседз 1із+. 


Мы знаем, что столбец іпёегеѕізѕ можно свя- 
зать с другой таблицей связью типа «один-ко- 
многим». Столбец ѕеекіпо тоже необходимо 
исправить аналогичным образом. После этих 
изменений таблица будет соответствовать кри- 


териям первой нормальной формы*. 


Но мы не можем остановиться на первой 
нормальной форме — нормализацию необхо- 
димо продолжить. Чем сильнее нормализуется 
таблица, тем проще получить из нее данные 
посредством запроса (или соединения — см. сле- 
дующую главу). Но прежде чем создавать новую 
схему для базы данных дгедѕ 113%, мы позна- 
комимся с другими уровнями нормализации. 


сотасі іа0"=# 


іаѕї пате 


* Вам захоилелось вернупься на не- 
сколько глав назад, чилобы Вспомнииль, 
чило илакое первая нормальная форма? 
Не нужно, мы напомним вам на следу - 
ющей силранице. 
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Не 8 первой нормальной форме 


Мы упомянули о первой нормальной форме. Давай- 
те еще раз вспомним, что это такое, а потом про- 
должим нормализацию до второй и даже третьей 
нормальной формы. 


Итак, таблица, находящаяся в первой нормальной 
форме, должна удовлетворять следующим условиям. 


Первая нормальная форма, или ІНФ: 


Правило 1. Столбцы содержат только атомарные значения. 
Правило 2. В таблице нет повторяющихея групи данных. 


Изображенные ниже таблицы не соответствуют 
требованиям первой нормальной формы. Обрати- 

те внимание: во второй таблице добавились новые 
столбцы для цветов, но сами цвета при этом повторя- 
ются в записи. 


Не находится в 1НФ 


[Г св | 
фрисби 
зеленыи 


белый, желтый 


[у | 
ЕЕ 


Чилобы Силолдец <«со[оусэ> 
дыл аиломарным, он должен 
содержаиль илолько один 

из эилих ивеилов, ане2 или 
5 6 одной записи. 
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Все равно не находится в 1НФ 


[5 | мяч | белый | желтый 
| 6 | фрисби зеленый | желый | | 


красныи 


мяч 
воздушный синий зеленый 
змей 
йо-ио белый желтый [| 


44; —— 5р 


ре 


Эила илаблица все еще не 1НФ, 
иоилому Чило силолбиы Все еще 
содержал иле же липы дан- 
ных, все МАВСНАВ с ивеилами 
игрушек. 
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Наконец-то — 1НФ... 


Давайте посмотрим, что здесь нужно сделать. 
В1НФ 


Первичный Внешний ключ. 


ключ. т 


129 


Каждая Запись 


содержиил ИлодЬКко 


е 
с ин ивеил, и Вее 
= Записи уникальны. 


ним К 
Внеш КРА линии 


бязаилелено` 


тесла значения силолбиов 
209 14» и «сојоруу образуюил 


Ч первичный клон. 


уникальны 


Столбец соу іа в отдельной таблице в качестве 
внешнего ключа — это нормально, потому что 
хранимые в нем значения не обязаны быть уни- 
кальными. При добавлении в эту таблицу значе- 
ний со1ог все записи уникальны, потому что 
цвет В СОЧЕТАНИИ с оу іа образует уникаль 
ную комбинацию. 


Первичный ключ из не- 

скольких столбцов? Но разве 
первичный ключ не должен быть 
только одним столбцом? 


Нет. Ключ, состоящий из двух 
и более столбцов, называется 
составным ключом. 


Рассмотрим еще несколько примеров 
использования составных ключей. 
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подробнее о составных ключах 


Составные Ключи состоят из нескольких столбцов 


До настоящего момента мы рассматривали связи данных 
таблицы с другими таблицами («один-к-одному», «один-ко- 
многим»). Однако пока ничего не было сказано о том, как 
столбцы таблицы связываются друг с другом. А без это- 

го понять суть второй и третьей нормальных форм невоз- 
можно. Но зато потом намного упростится создание схем Б 
баз данных с запросами к нескольким таблицам. 


Для использования соеди - 
нений (комлорыми мы 
займемся 6 следующей 
главе) илаблицы должны 
Итак, что же такое «составной ключ»? имеме хорошо: сироек» 


илированную силрукилури! 
СОСТАВНЫМ КЛЮЧОМ называется 

ПЕРВИЧНЫЙ КЛЮЧ, состоящий из 

нескольких столбцов, комбинация ко- О =} г 

торых образует уникальные значения. 


Возьмем следующую таблицу с информацией о супергероях. 
Таблица не имеет уникального ключа, но мы можем создать 
составной первичный ключ из столбцов папе и ромег. Хотя 
в каждом из этих столбцов могут встречаться повторяющие- 
ся значения, их комбинация всегда уникальна. 


При создании эилой илаблииы можно указаиль, чило эили два пол 
образуюил сосилавной первичный ключ. Предиолагаеился, чило | 
супергерои с одинаковыми именами никогда не обладакоил оди- 
наковыми сциерспособносилями, илак чило сочелание эилих двух 


значений 
уникально. р зирег Һегоез 


— 


[| мате ческие; 


другие супермачо 
моц. 


Нарисованный Изображает людей игра «Виселица» 
Человечек 
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Даже супергерои от чего-нибудь зависят 


У наших супергероев много работы! Перед вами об- 


новленная таблица зџрег һегоез. Она соответствует Еели изменение содержи- 
требованиям ІНФ, возникает гая проблема. 
4 ОА АЕ мого одного столбца долж- 


Столбец іпіёіа15 содержит сокращение, то есть на- 


чальные буквы значения столбца папе. А что произой- но приводить к изменению 
дет, если супергерой вдруг захочет сменить имя? 
Точно, содержимое столбца іпіёіа15 тоже должно другого А говорят, ЧТО ВТО- 


измениться. Говорят, что столбец іпіёіа1ѕ функцио- 


нально зависим от столбца папе. рой етолбец функционально 


8 сочеилании 

а имени совладаюил, но 

о силолбиа «ромег» создается зависим от первого. 
б м м 

уникальный сосилавной первичный ключ. ы 

/ зирег_Вегоез 


| пете Оф |  рочегО+х | меакиев; |__<Му | соопту | ағеһ опоту — | ши» | 
Моментально убирает мусор | отбеливатель США 
птицы __| Метрополис |_ США 


Е 


Нарисованный Изображает людей игра «Висе- Лондон Англия Ластик НЧ 
Человечек лица» 


‚Возьми в руку карандаш 


чы, Итак, в таблице супергероев столбец і пії і а1 ѕ зависим от столб- 
``. ца пате. А вы видите еще какие-нибудь похожие зависимости? 
Запишите их здесь. 
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возьми в руку карандаш. решение 


Возьми в руку карандаш 


“ | 
``. Решение 


плов зависиил оил паиле Из эилой записи не ясно, в какой 
эн. илаблице находяился силолдиы; эило 
игеаклеѕѕ зависиил оил маиле «__ можеил быть сущесилвенно ири д0- 
бавлении новых илаблиц. Суиесилвцеил 
аксі елемлу зависиил оил пате <—^ специальный сокраиденный синилаксис 
Эля обозначения эилих зависимостей 
сту забисиил оил соииїту "96 и илаблии, 8 коилорых они находяился. 


Итак, в таблице супергероев столбец іпії і а1 $ зависим от столб- 
ца пате. А вы видите еще какие-нибудь похожие зависимости? 
Запишите их здесь. 


Сокращенная запись 


Для компактного описания функциональных зависимостей часто использу- 
ется следующая запись: 


Т.х => Т.у 


Это можно прочитать так: «В таблице с именем Т столбец у функционально 
зависит от столбца х». Зависимый столбец указывается в правой части. 


№ по базам данных 


Применительно к нашим супергероям это выглядит так: 
зирег Һегоеѕ.патме —> зарег Вегоез. 1п161а15 
«В таблице зирег_вегоез столбец 1п1Е1а15$ функционально зависит 


от столбца пате». 


зарег Һегоеѕ.пате —> зирег Һегоеѕ.меакпезз 


«В таблице зџрег һегоеѕ столбец меакпеѕз функционально зависит 
от столбца пате». 


зирег Һегоеѕ.пате —> зирег Һегоеѕ.агсһ епему 


«В таблице зирег_пегоез столбец агсп_епету функционально зависит 
от столбца пате». 


зирег Вегоез.соипекгу —> зирег Һегоеѕ.сібу 


«В таблице зирег_вегоез столбец сісу функционально зависит 
от столбца соип® гу». 
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Суперзероцекие зависимости 


Итак, если наш супергерой поменяет имя, столбец 
іпіііа1ѕ тоже должен измениться; это означает, что 
столбец зависит от столбца папе. 


(й 
ли Нарисование Е 
8  еловечек вдрче 3а 


себя 
б азываиле 
Если заклятый враг супергероя решит переехать бе фиком, ило 

в другой город, то изменится его текущее место- Диси^р 6 «пл На $» 
нахождение — и только. Таким образом, столбец ви делся из- 


р и 
агсһ епету сіѓёу в приведенной ниже таблице иложе и 
абсолютно независим. \ М мении^е- 


Зависимым называется столбец с данными, которые 
могут измениться в случае изменения другого столб- 
ца. Независимые столбцы существуют сами по себе. 


Частичные функциональные зависимости ГАА 
Ё 


Частичная функциональная зависимость означает, и: 
.. а 
что не-ключевой столбец зависит от некоторых, но не Тем временем 


от всех столбцов составного первичного ключа. переехал в новый С род, 
7 А но на другие суол це! 
В нашей таблице столбец іпіёіа1 $ частично неза- эило никак не повлияло. 


висим от пате, потому что в случае изменения имени 
супергероя столбец іпіііаі1з тоже изменится, 
а в случае изменения ромег (но не пате!) столбец 


10161а1$ останется неизменным. С 
окращение забисиил оил 


ч ЧА имени, но не оил скер - 
ый С сиосодносилей 


Силолб [2 › ПоЗУдомы 
{ << 9 
и о. ра. эма илаблииа собе жил 
>> ; 
сосилавной Месиле одразуноуд часиличную функцио ~ 
первичных Ключ. зирег Һегоезѕ нальную зависиллосидь. 
ох 


4 
|___тапёфя |__ромбфт _ | меакпезғ| «Ну | | 
Супер-Мусорщик | Моментально убирает мусор 
моц. 
Супер-Парень 5 
5 
т 


я 

В 

б 

[Зудо-Официзнт | Никохда не забывает заказы [ насекомые | Париж | парик 
Е 

[Г зиеятета — | Бывает очень очень злой | мы | вм | 

Ё 

б 

5 


мо с 


Нарисованный Изображает людей игра Лондон 
Человечек «Виселица» 


З Луисвиль 
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Язык справедливости насекомые Лондон {Тт | 


транзитивные функциональные Е Ела 


Транзитивные функциональные зависимости 


Также необходимо учесть и связи всех неключевых 
столбцов с другими столбцами. Если заклятый враг 
какого-либо супергероя переедет в другой город, его 
значение агсһ епету іЯ от этого не изменится. 


Значение «ас елемлу ій» не изменилось 
хоиля Неряха и переехал 6 К.анзас-Сиили. 


А Р Е 
пато офи [иа опоту аага пету цу | 
Супер-Мусорщик[ \ 4 — 4%. Канзас-Сити | 
87 

і 
[_ Париж | 
[Канзас-Сити _ 


Если изменение не-клю- 
чевого столбца может 
нривести к изменению 
других столбцов, значит, 


Супер-Парень 
Чудо-Официант Париж 
Канзас-Сити 


Предположим, супергерой захотел поменять 
себе заклятого врага. Значение агсһ епету іа существу ет транзитивная 
при этом изменится, а это может привести к из- 

зависимость. 


менению агсһ епету сіу. 


Если изменение не-ключевого столбца приводит 
к изменению других столбцов, значит, существу- 


ет транзитивная з 0 Ь. 
р ависимост Если обновление «аси епвили_164>> 
о ц_ 


я ириводиил к изменению значения 
Та б силолдие »агси_елеили сц»... 
= = 
Є нету) 
Супер Мусорщик „эло называется илранзииливцой 
П а 
Г__Брокер | 8 | Ньюарк | функциональной зависимо 
Супер-Парень иоилому Чило не-ключевой а 
до официант бец «гей елетц сіу обяз 
ИО «акс оО 
> ы -19>>, коило- 
Реи илакже являеился це -КАюЮЧевым 


Транзитивная функциональная зави- 
еимоеть: не-ключевой столбец связан 
е другими не-ключевыми столбцами. 
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многотабличные базы данных 


В следующей таблице хранится информация о книгах. Столбец рир іа определяет 
издателя, а столбец рир с1еу — город, в котором была опубликована книга. 
пражнение зда ц рор сіу род р у 


Гааги нис  [зовунвы р [ вовну | 
Нью-Йорк 
Бостон 
Сан-Франциско 
Нью-Йорк 


Напишите, что произойдет со значением столбца соругісћі, если столбец сі с1е в третьей 
записи примет значение «Вытащите Тимми из колодца!». 


ниё «соруеаћь». ЙОЗИЛОМу его значе – 
ние измениилс 
Я. 


Что произойдет со значением столцба соругіоћх, если автор книги в третьей записи 
изменится, а название останется прежним? 


Что произойдет с записью «В мире с природой», если ее полю рир іа будет присвоено 
значение 1? 


Что произойдет со значением рор іа записи «Я ненавижу Люси», если издатель пере- 
местится в другой город? 


Что произойдет со значением рир сісу записи «Я ненавижу Люси», если ее полю рор іа 
будет присвоено значение 1? 
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упражнение. ответ 


В следующей таблице хранится информация о книгах. Столбец рир іа определяет 
издателя, а столбец рор сісу — город, в котором была опубликована книга. 


пражнение 


р нение Напишите, что произойдет со значением столбца соругісће, если столбец е1Е1е в третьей 
записи примет значение «Вытащите Тимми из колодца!». Силолдец <соруичИЕ>» зави- 
При изменении названия измениился сиил ом <«НЫе>, поэиломи 
и значение «соруиаи>. к 


Что произойдет со значением столцба соругідћі, если автор книги в третьей записи 
изменится, а название останется прежним? 
При изменении авилора, но не названия измениился и значение 


«сорцгідћё». 4) 


Автор и назва - 
ние Вмесиле оё - 


Разукоил сосилав- <Сорунайь» зависиил 
Ной первичный Оил названия и оил 
Ключ С, | с авилора. 
Гашо О+т |_ нне Ох [серу | | ри у 
1930 


1968 
1950 Сан-Франциско 
Лесси, успокойся Нью-Йорк 


Что произойдет с записью «В мире с природой», если ее полю роь іа будет присвоено 


значение 1? «риб _сіёу» для «рир 4 1» и «рир іа 2» — 
«рир сіёу» не измениилбя. Нею-Иорк, поэилому город не меняеился 


С ЗаВиди (даже когда «рир сієц» зависиил оил «риб іа»). 
сиил оил силолд - . | 
ца рир сіц, Что произойдет со значением рир і @ записи «Я ненавижу Люси», если издатель пере- 


й ? 
и поэилому местится в другой город? 
осплается 7 <«рир_14>> осилаеился илем же. 


мел же. 
Что произойдет со значением рор сі су записи «Я ненавижу Люси», если ее полю рор іа 
Р" будет присвоено значение 1? е" «рир сц» зависим оил зна- 
рир сіу» илранзи- «рир сіу» силановиился Нью-Иорк. \( чения в силолбие «рир ій» — 
ивно зависиил ИЙ: оар но ванае бае о а нук бан рене аА “5 улранзииливная функцио - 


ир 12», АЕ нальная зависимосиль. 
ачение меняемся. е 


Гоњо от | мне оя Гееруніае Г рење Грав зн 
[Джон Дир | В миресприродой | 1930 


) 


1950 
1951 
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часто 


. Существует ли простой способ устранения частич- 
ных функциональных зависимостей? 


(} Использование столбца-идентификатора, как в таблице 
ту сопбасїѕ, полностью решает все проблемы. Так как 

этот столбец представляет собой новый ключ, который со- 
здается только дпя индексирования этой таблицы, никакие 


алаВаеМые 


Восы 


многотабличные базы данных 


‚ Когда и зачем мне могут потребоваться составные 
ключи из столбцов таблицы (если не считать соеди- 
нительных таблиц)? Почему нельзя всегда создавать 
столбец-идентификатор? 


() Безусловно, это решает проблему. Однако попробуйте 
провести поиск в Интернете по условию «синтетические или 


естественные ключи» — вы найдете убедительные аргумен- 
ты в пользу обоих решений, а также немало горячих споров. 
Лучше, если вы примете решение самостоятельно. В этой 
книге в основном используется решение с синтетическим 
ключом, чтобы вы смогли понять суть концепции, не отвле- 
каясь на тонкости реализации. 


другие столбцы от него не зависят. 


Зависимости — это, конечно, хорошо. 
Но какое отношение они имеют к переходу 
от первой нормальной формы ко второй? 


Включение столбцов первичных ключей 
в таблицы способствует выполнению 
требований 2НФ. 


Для простоты и удобства, а также для обеспече- 
пия уникальности мы обычно включали во все 
свои таблицы столбцы, которые использовались 
как первичные ключи. Это способствует выпол- 
нению требований 2НФ, потому что вторая нор- 
мальная форма определяет связь первичного ключа 
таблицы с хранящимися в ней данными. 
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преобразование таблиц в 2НФ 


Вторая нормальная форма 


Как покажут следующие две таблицы, используе- 
мые в системе складского учета магазинов игрушек, 
требования второй нормальной формы относятся 
к отношениям между первичным ключом таблицы 
и хранящимися в ней данными. 


Сосилавной ключ. 


К 


и ру 
тоу зїогғе_ 
©+ іа 0х 


зеленый 


оу 14 | 
[6 | фрисби 
9] 


10 


1902 Эмберлайн 


воздушныи змеи 


зїоге_айбгезз Силолдеи содержиил 


много дубликаилов, 
причем эили дубли - 
каилы! не содержаил 
полезной инфор- 


желтый 24 


17 Инглсайд мации об игруш - 


ках: они оилносяился 


красный 23 Мейпл 
синий 1902 Эмберлайн к дазазыни 
зеленый | 1902 Эмберлайн 
12 белый 28 17 Инглсайд 
12 желтый 1 17 Инглсайд 


Над эилим силолбцом иложе силоиил хо- 
рошенько подумаиль. Эили данные ско- 
рее должны храниилься В илаблице игру- 
шек, а не 6 складских данных. Силолдец 
<воц14> должен иденилифицироваиль 
как илии, ТАК И ивеил игрушки. 


Обратите внимание на дублирование ѕіоге аЧагезз 
для игрушек, связанных с идентификатором магазина 
зіоге іа. Если нам вдруг понадобится изменить адрес 
магазина, придется изменять каждую запись таблицы, 

в которой он присутствует. Чем больше записей обнов- 
ляется с течением времени, тем выше вероятность того, 
что в данных появятся случайные ошибки. 


С другой стороны, если выделить столбец зе оге _ 
аЧагез5 в отдельную таблицу, то адрес будет достаточ- 
но изменить только в одном месте. 
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Количесилво единиц иловара 
зависиил оил обоих силолб- 
цов, образующих сосилавной 
первичный ключ, поэтому 
часиличная функииональная 
зависимосиль оилецилсилвцеил. 


мнозотабличные базы данных 


Возможно, таблица уже находится 8 2НФ... 


Таблица ІНФ также находится в 2НФ, если все столб- 


цы таблицы являются частью первичного ключа. : Таблица 1НФ находится 
Мы можем создать новую таблицу с составным первич- : в 2НФ, если все столбцы 
ным ключом из столбцов іоу іаи ѕёоге іа. Тогда : таблицы являются частью 
в одной таблице будет храниться вся информация об : первичного ключа _ 
игрушках, в другой — вся информация о магазинах, : — == 

а новая таблица будет связывать эти две таблицы. з ИЛИ 


она имеет одностолбцо- 
вый первичный ключ. 


Вся информация о них. 


сїоге іа 


Таблица ІНФ также находится в 2НФ, если она 
имеет одностолбцовый первичный ключ. 


И это хорошая причина для создания столбца- 
идентификатора с условием АОТО ІМСВЕМЕМТ. 


Вторая нормальная форма, или 2НФ: 

Правило 1. Таблица находитея в ІНФ. 

Правило 2. Таблица не имеет частичных функцио - 
нальных зависимостей. 


Вряд ли в ту _сопїасіѕ есть 
частичные функциональные 
зависимости, хотя... 


Значит, пора поиграть... 


озпьше + 361 


станьте таблицей 2НФ 


(зпаньтре трабЛицей + с ЧастиЧныМи 


ФункциональньМи заВвисиМосряМи 


уелававьюе себя на Местре тпаёЛиЦы 


и чсклюЧитое из себя Все Частрич — Эили два 
ные Функциональные заВиси— силолдца 
Й образунои^ е, 
меа, | хала» аа зрелатив  оникаләной 
Ленных тоабЛиц Вычеркнитре тпе сос илавной ми 


чный 
стролёЦы, Которые Лучше перемеспшпь пербвичн 
ключ. 
В отодельную траёлицу, 


даїе 


[аѕ51 пате 


Яг${ пате 


адепсу _ѕїаїе 


әй 


етріоуее і 
1а5{ пате 
Яг5{ пате 

ѕаіагу 
пападег 


етріоуее _етай 


ге _дае 
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‚Возьми в руку карандош 


Қ. 


Пигу 
[6 | фрисви- 
ШШЕ 
ныи змеи 


многотабличные базы данных 


Преобразуйте эти таблицы в три таблицы, соответствующие требованиям 2НФ. 


Одна таблица должна содержать информацию об игрушках, другая — о ма- 
газинах, а третья — содержать данные о наличии товара и связывать первые 
две между собой. Присвойте всем трем таблицам содержательные имена. 


Добавьте в соответствующие таблицы столбцы рпопе, тападег, соѕі 
и меісћі. Возможно, вам придется создать новые значения іоу іа. 


й 
ВЕЕТ ЕЕ 
я 
Есей 


красныи 
синии 


Й 23 Мейпл 
зеленый 


белый 
желтый 
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станьте таблицей 2нф. ответ 


В отодеЛьную траблицу, 


Первичный ключ. 


Хоиля здесь сле- 
довало ды раз- 
месилииль иден- 
илификаилор из 
илаблицы аделсу 
(два агенилсилва 
могуил имеиль 
одинаковые назва - 
— ния), часиличной 
ункционаленой 
зависимосили неи“ 


БИСИ 


Первичный 
ключ. 


Эилим дан ~ 
ным здесь 

не месило, 

но часиличной 
функциональ 
ной зависи ~ 
мМосили неил. 
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и исключите из себя Все ЧастриЧ— 
ные Функциональные заВиси— 
Мостри, і каждой из представ 
Ленных траёЛиц Вычеркните те 
стелёцы, Котпорые Лучше переместитпь 


(зраньхое трабЛицей 2% с частричньМи 


Функциональньми заВисиМострямМи, (зовет 


релетавьте себя на Местре трабЛиЦы 


Эили два 
силолбиа 


образуюил Э 


цникаленый 
сосилавной 
первичный 
ключ. 


еван 


і+ғ#өөр—еадег 


После исключения эилих 
силолбиов осилавилиеся 
2 образуюил сосилавной 
є иервичный ключ. 


Первичный 
ключ. 


Е поме іа 
е 


Эили силолдиы 
депге 


связаны илолеко 


илранзииливной гепіеа_Бу 
функциональной > це _даїе 
зависимосилею. гало 


Сосилавной иер - 
Вичный ключ. 


Силолбец «сиб» Можем на- 

ходиилься 6 зилой илаблиие (если 
< эило связь «один-к-одномч>»), 
қ силолбиц <<сіиб ѕЁафе» здесь явно 

не месило. Но несмоилря на эмо, 
среди силолбиов неил часиличных 
функциональных зависимостей. 


мнозотабличные базы данных 


Возьми в руку карандаш 


: ЕЯ 
р 
9749 


і“ Преобразуйте эти таблицы в три таблицы, соответствующие требованиям 2НФ. 


Одна таблица должна содержать информацию об игрушках, другая — о ма- 
газинах, а третья — содержать данные о наличии товара и связывать первые 
две между собой. Присвойте всем трем таблицам содержательные имена. 


Добавьте в соответствующие таблицы столбцы рћопе, тападег, соѕі 
и меісћі. Возможно, вам придется создать новые значения їоу іа. 


белый 


желтый 


23 Мейпл 
СИНИЙ 


л 
І 


воздушный 


змей зеленый 


Л 


красный 


СИНИЙ 
зеленый 


белый 


желтый 


Сосилавной первичный 
ключ сосилоиил 

из силолдиов «оу 14» 
и <<ѕёоке (>>. 


1 
3 
1 
2 
4 


фрисби | желтый | 1.50 
5.75 


змей 


воздушный 
змей 


ѕіоге іпѓо 


23 Мейпл 


1902 Эмберлайн | 555-3478 
100 Норт-стрит [555-0987 
555-6554 
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переход к ЗНФ 


Третья нормальная форма (наконец-то!) 


Так как в книге мы по возможности добавляем «син- 

тетические» первичные ключи, с переводом таблиц Кели таблица имеет син- 
во вторую нормальную форму обычно проблем не о ө 
бывает. Любая таблица с синтетическим первич- тетическии первичный 

ным ключом, не имеющая составного первичного 

ключа, всегда находится в НФ. КЛЮЧ и не имеет составно- 
Как убедиться, что мы в ЗНФ? го первичного ключа, она 


находится в 2НФ. 


Еще не забыли? Транзи = 


Третья нормальная форма, или ЗНФ: 
ионаленая 
Правило І. Таблица находится в НФ. "67 адом 


<— наличие связей между не - 


Правило 2. Таблица не имеет транзи- = оов силолбиами. 
ТИВНЫХ зависимостей. Если изменение какого - 


либо не-ключевого 
силолбиа можем приве: 
сили к изменению дру- 


о произойдет ари изменении значения какого- гих силолбиов, имееил 
ли _ из трех с м цов: сочгзе папе (название месило илранзииливная 
учебпого курса), іпзёгисёог (преподаватель) ООВ: 


и іпѕёгисёог рћһопе (тслефон преподавателя). 


\ 


пе изменяются. ый 


= При изменении іпзігисіог значение Чилобы илаблица сооилвеил- 
іпзёгисёог рћопе изменится. Мы об 7 силвовала илребованиям НФ, 

наружили транзитивную зависимость. из нее необходимо убраиль 
силолбем «<ілѕъгисог_рћотље»- 


При рассмо- _ 
илрении 5Нф М 
на первичный 
Ключ можно 

не одращаиль 
Внимания. 


> При измепении соцгѕе пате 
ни 1тозбегиасбох, ни іпѕігисёог _ 
рһопе не изменяются. 


=> При изменении 1п5егисвог рћопе 
ни іпзі гисгог, ни соигзе паме 
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многотабличные базы данных 


Что делать с таблицей ту_соп+ас+? 


В нее необходимо внести несколько изменений. Начните с текущей версии таблицы 

ту сопёасёз и изобразите новую схему дгесз 1ізї. Обозначьте связи между внеш- 
ними ключами линиями, а связи типа «один-ко-многим» — стрелками. Также обозначьте 
первичные и составные ключи. 


пражнение 


согіасі іа Ож 


і] 


С Подсказка. Наша бес, 
на следующем силраниц 


сосилоиил из 8 арми 
(Мы добавили силолде\ 
для мочилового индекса, 
д до эмого было 7.) 
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упражнение. решение 


М Что делать с таблицей ту __сопѓасіс? 
пражнение 
Е оңуе В нее необходимо внести несколько изменений. Начните с текущей версии таблицы 

ВЕ ту сопіасїз и изобразите новую схему дхедз_113+. Обозначьте связи между внеш- 
ними ключами линиями, а связи типа «один-ко-многим» — стрелками. Также обо- 
значьте первичные и составные ключи. 


ЕЕ222 298 Связь «многие -ко -Многим»» сосилоиил 
соттаса из двух связей «один-ко-многим> 
и соединиилельной илаблицеі. 


Два силолдиа образуюил 
Исосилавной ключ. 


чодин-ко-многим»» 


многим” \, 
«одинўко -МН 5 сопїасі_ 9 к |( 


— 
| ммегем | 
0х к 
В илаблице <«сопфасе. 
| вау сопёасёз | ГлЕекеѕі» неко- 
Сі 14 0 илорое значение 
Эили илри связи оилносяился “ед. _ Е 
ыы х | бы пате | =” Өк, всилречаилься много т 
| мое | им», краилно, а в илаблице 
У роте «<іувемеѕѕ» — илолько 
ета СНЫ 10 
т сопіасі_ 19 о 
Г 


7 24 ѕеекіпо_іа О 


я 

ргої 19 к 1 ѕеекіпо_19 5 
ШЕГИ ок М. 
Ѕ{аїиѕ іа = ) «один -коуќногим» 


Д 
ца одразу ЗУМ 
сосилавной 
Клкоч, 


Е) м> 


Связь «мног 


ей 
= сосилоиил из 064Х связ а 
«один -ко-мМногиМ»? И с 
ниилельной илаблицы. 
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мнодсипабличные базы данных 


...А далее Реджи (и дгед 11+) 
ждало счастливое будущее... 


Грег смог найти идеальную пару для Реджи по своей 
новой нормализованной базе данных — и не только для 
Реджи, но и многим своим друзьям, и его мечты сбы- 
лись. В общем, все кончилось хорошо. 


Стоп, не так быстро! Теперь 
мне нужно составить запросы ко 
всем этим новым таблицам! Как получить 

данные из набора связанных таблиц без на- 
писания сотни-другой запросов? 


Вас спасут соединения. 


До встречи в следующей главе... 
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краткий :05ор за! 


ГЛАВА 7 


370 


Новые инструменты 


Поздравляем, вы одолели больше 
половины книги. Напоминаем 
ключевые термины, которые вы узнали 
в главе 7. Полный список инструментов 
приведен в приложении 11. 


Первая нормальная форма (1Н%Ф) 


Силолдиы содержаил илолько 
диломарные значения и 6 них 
оилецилсилвунюил повилоряю- 
шщиєся группы данных. 


Схема 


Описание данных, хра- 
нимых 6 базе данных, 
включающее все объек- 
илы и связи между ними. 


Транзитивная функциональ- 
Ная зависимость 


Не-ключевой силолдец свя- 


зан с другим не-ключевым 
Я) силолдиом ( -ами). 


Вторая нормальная форма (28%) 


Таблица находиился 6 1НФ 
и не содержиил часиличных 
функциональных зависимо- 
силей. 


И 


| Связь «один-ко-многим» 


| Замись одной илаблицы Третья нормальная форма (зне) 
можеил дбыиль связана со 
многими записями дру- 
гой илаблицы, но каждая 
запись последней можем 
быиль связана илолько с Внешний ключ 
одной записью 6 первой. 


Таблица находиился 6 2НФ 

и не имеел илранзииливных 

зависимосилей. 
н 


ОЕ илаблицы, значе ~ 
С ' Коилорого ссылаюился 
ербичный ключ другой 


— 


многим» 


(м связывал З 


Связь «многие-ко_ 
Две илаблиц 
ся через сое 


иладлицы. 


| Составной КЛЮЧ 


Первичный ключ, С0- 


й из несколеких ^ 
в, комбинация 


вил Уни- 
оплорых образу 
й Р чение КЛЮЧА. 


| каленое зна 
| 
1 


«Возьми в руку карандаш 


чы Решение 


многотабличные базы данных 


Используя команду АГТЕВ и функцию ЗОВЗТВТМС ІМРЕХ, из- 


қ. мените таблицу так, чтобы таблица состояла из перечисленных 


Прежде всего необходимо 
создаиль новые силолдиы: 


АГТЕК ТАВІЕ му сопбас®$ 
АБР СОБОММ 1пЕегез®1 УАВСНАВ (50), 


столбцов. Количество запросов не ограничивается. 


сопфасе_ іа 
1азЕ_ пате 
Ғігѕ пате 


АБР СОГОММ іпбегеѕ2 УААСНАК (50), рћһопе 
АБР СОГОММ іпбегеѕЗ УАВСНАВ (50), ў 
АБО СОБОММ іпбегеѕ4 УАВСНАВ (50); @та11 
Заилем первое увлечение переносиился 6 новый силол- депаег 
дец <<іліегеѕЕ1 >». Эило можно сделаиль илак: Ьіг+ћаау 
ОРРАТЕ ту сопсасёѕ ргоѓеѕзіоп 
ЗЕТ іпіегеѕӯі = Ѕ0ОВЅТКІМС ТМОЕХ (іпбегеѕіѕ, ',', 1); сіу 
Первое увлечение, сохраненное 6 «ім+екеѕ+1», нужно уда - зфафе 
лить из силолбиа << тфеге$5>. Удаляюился все символы до з+аеиз 
первой замяилой включиилельно: ; 
в ФК ілёегезі1 
7 
Функция ТЕІМ чдаляеил пробелы у левого раи АНТ воз зпьегезЕ2 


брашщалеџрл правую 


ы чда- 
края силроки после илого, как М 
Ў с ( Часиль силрокового ітбегеѕіЗ 


лим все символы вилоиль до заляилой. 


зна А 
чения. 1п%егез+4 
ОРРАТЕ ту сопёасёѕ ЅЕТ 1п%егез®ез = ТКІМ(КІСНТ (іпбегеѕіѕ, кі 
(БЕМСТН (іпёегеѕіѕ) -ТЕМСТН (іпёегеѕё1) — 1))); янь 
е А эила усилрамлающая консилрукция бочисляеил длин) зн ча - 
сили силолдиа <<илфеге$$>. Из общей длины <<ѓи+емеѕі<. бома славид = 
ся длина часили, перемещенной 6 <<ифеге5Ё1». Заилемл лае Выцила- 
ем еще 1, чилоды цсеченное значение начиналось посл. запяизой. 
Зили дейсилвия мовилоряюился для осилальных 
силолдцов увлечений: 
ОРрАТЕ ту сопсасіѕ ЗЕТ іпбегеѕё2 = ЗОВЗТВТМС ТМОЕХ (іпіегеѕёѕ, ',', 1); 
ОРРАТЕ ту сопбасіѕ ЅЕТ іпёегеѕєѕ = ТКІМ(КІСНТ (іпёегеѕіѕ, (ТЕМСТН (іпёегеѕіёѕ) - 


ТЕМСТН (іпёегеѕ5+2) — 1))); 
ОРРАТЕ ту сопёасіѕ ЗЕТ іпёегеѕі3 
ОРРАТЕ ту сопіасіѕ ЅЕТ іпіегеѕіѕ 
ТЕМСТН (іпёегеѕе3) — 1))); 


ЅОВЭТКІМС ІМРЕХ (іпбегеѕіѕ, ',', 1); 
ТКІМ (ВТСНТ (іпбегеѕёѕ, (ІЕМСТН (іпбегеѕіёѕ) - 


Для последнего силолбиа осилалось илолько одно значение: 
ОРРАТЕ ту сопёасіѕ ЗЕТ іпбегеѕі4 = 1п%егез{з; 


Темерь силолбец <'ифеге5> можно полносилью удалить. 
Также можно было переименоваиль его 6 «ілекеѕъ4>»› 

и избавиилься оил лишней команды АРР согомм 
(иредлолагаеился, чило увлечений не более чемлырех). 
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упражнение. решение 


Напишите для Реджи запрос, не использующий столбец іпіегеѕіѕ. 


пражнение 


|оошенис ЅЕЕСТ * ЕКОМ илу солёас+ѕ 
Сос. 316. М/НЕВЕ делдек = 'Ж' 
АМР ѕЅѓаёиѕ = ‘Не замужем! 


Факилически эило илоил 
же запрос, коморый Грег 


АМР” ѕёафе=' МА! использовал для Найдже- 


| 7 ла, 
АМР зеекта ШКЕ '%Неженаилый "АБК дез проверки 
силолдиа <<тиТегесес»». 


мужчина?! 
АМР біт+раау > 1950-20-05 


АМР Биладу < '1960-20-05'; 
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8 ( оединения и МноГотрабЛиЧные операции 


* Не могли бы мы 
остаться в одиночестве? + 


Пожалуйста, уйди, Жак. 
Нас твои «внешние 
ключи» не интересуют. 


Добро пожаловать в многотабличный мир! Базы данных, состоя- 
щие из нескольких таблиц, удобны, но чтобы успешно работать с ними, вам 
придется освоить некоторые новые инструменты и приемы. При работе с 
несколькими таблицами может возникнуть путаница, поэтому вам понадобятся 
псевдонимы. А соединения помогут установить связь между таблицами, что- 
бы снова собрать воедино информацию, разбросанную по разным таблицам. 
Приготовьтесь, пора снова взять базу данных под свой полный контроль! 


база данных: = #0 же самое 


Ш Все рано повторения, повторения... 


Грег заметил, что в столбцах ргоҒеѕѕіоп. іпіегеѕіѕ 
и зеек1пд постоянпо встречаются одни и те же значепия. 


Пол Собел | неженат | ў +4. Диана Рейли 
ига не женат ; СРЕ. 
м женщина адбокаиќ" 
женат 
учиилель живоилные 


книги 
книги 


музыка 
ѕзеекіпа о ЗОлЛЦЖЕеЛА —, 
\ 
не замужем у мужа 
[Мэри Харрисон | Харрисон} аа | женщина | вок И 
Ш Ё—> адвокаил Вер 
ежи м: 
адвокаил 
спорил 
музыка | ртееззіов | 


не женаил 
қ 
у 
М ча МИА ы РУР 


адвокат 
М“ Є. 
живомные 


адвокаил 


а, не жена БЕ 
не женаил | тем» | женщина 
Эндрю Уорнер а ЕЖак Пеннингтон } 
2% Б музыка __| " с 
жениина музыка е 
книги 
САИ 
спорил 


замужем а 


не замужем МОЦ 
Руби Гордон —_ 
" оа программист таарна 


мужчина Ув 
26 книги 
асбокаил спорил 
книги 
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Заполнение таблиц 


Обилие повторяющихся значений упро- 
щает заполнение таблиц ргоЕезз1оп, 
1п%егез(з и зееК1 па. Грег хочет запол- 
нить эти таблицы значениями, уже храня- 
щимися в старой таблице шу_сопвасЕ$. 


Но сначала необходимо составить за- 
прос и узнать, какие данные уже хранятся 
в таблице — и каким-то образом обойтись 
без огромного списка дубликатов. 


Возьми в руку карандаш 


. Напишите запросы, возвращающие список значений столбцов 
и“ ргоѓеѕѕіоп, і піегеѕіѕ и зееК1па уа1щез из старой таблицы 
пу сопіасёз. В списке не должно быть дубликатов. Вспомните 
задачу с продажей печенья из главы 6. 


соединения и многотабличные операции 


Получить набор значений, 
хранящихся в таблице, — 
вполне стандартная задача, 
верно? 
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возьми в руку карандаш. решение 


«. Возьми в руку карандаш 
№ ч Решение Напишите запросы, возвращающие список значений столбцов 
т. ргоѓеѕѕіоп, іпіегеѕіѕ и ѕзеекіпд уа1џез из старой 
таблицы ту сопбасіз. В списке не должно быть дубликатов. 
Вспомните задачу с продажей печенья из главы 6. 


ЅЕГЕСТ реоѓеѕѕіом ЕКОМ илуч_сои#ас{ 
12 авоОЧОР ВУ ргоѓєеѕѕіом 


р ОКРЕК ВУ ргоЕе5$10и; 


Условие ЧКОЦР Вү соединя- 
вил дудликаилы В одно зна_ 
чение для каждой груилы. 


Заилем условие ОКРЕК \ | 
ВУ циорядочиваеи сти - ‚ ЗЕЁЕСТ ѕеекілд ЕВОМ илу_соиасйв 


сок по алфавиту р ба СВОЦР ВУ ѕеекіпд 
е ОКРЕК ВУ ѕеекгмд; 
Ри нарушении порядка цсло- 
бий вы получите сообщение 
од ошибке. Условие ОКРЕВ Вү 


Всегда должно силояиль на ио - 
следнем месиле. 


авоиР В\ЦитегеЕс 
2 КРЕКБ ВУ гер; 


Но этот запрос не подойдет 
для столбца т+егез${$. Ведь 
в этом столбце хранится не- 
сколько значений, помните? 


Мы не сможем воспользоваться 
простым запросом ЗЕЁЕЕСТ для 
вывода информации об увлечениях. 
С такими значениями аналогичная команда 
ЗЕЪЕСТ работать не будет. 
музыка, животные, 


книги 


животные, книги 
спорт, музыка 
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соединения и многотабличные операции 


Проблемы е нормализацией 


Ненормализованная структура таблицы порождает массу 
проблем. Не существует простого способа извлечь эти 
значения из столбца іпіегеѕіѕ по одному. 


То, что у нас есть: 


ПЕНИИ ИИННИЙ Солои из иоблицы 
трут е. утте Илу _солЁдсс 


То, что должно быть: 


Силолбец новой 
Р илаблииы леке. 


четыре 


Может, вручную? Мы можем 
просмотреть каждую запись 
ту__соптасїѕ, а потом ввести каждое 
значение в новой таблице. 


2; мозговой 
ооа р. 


Как выделить не-атомарные значения 
в один столбец таблицы ілёегеѕіё 5? 


Прежде всего, это гигантский объем работы. 
Представьте, что таблица содержит тысячи 
записей. 

Во-вторых, ручная обработка сильно усложнит поиск 
дубликатов. С сотнями разных увлечений вам придется 
при каждом вводе смотреть, не было ли данное увлече- 
ние введено ранее. 


Зачем выполнять всю «черную работу» самостоятельно, 
рискуя натворить ошибок? Лучше поручить ее 501. 
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разделение текстовых данных 


Особые увлечения (етолбец) 


В одном довольно прямолинейном решении в таблице ту сопбасіѕ 
создаются четыре новых столбца для временного хранения обрабатывае- 
мых значений. После завершения обработки столбцы будут удалены. 


„ Возьми в руку карандаш 


Вы уже умеете пользоваться командой АТТЕБ; создайте в табли- 
> це ту сопіасіѕ четыре новых столбца. Присвойте им имена 
іпсегезі1, іпіегеѕі2, іпіекеѕіЗи іпіегезі4. 


Вот как будет выглядсть столбец іпсегезіз с новыми столбцами 
іпёегезіё в таблице ту сопёасіз после выполнения АТТЕВ. 


Первое увлечение копируется в новый столбец іпіегеѕі1 
при помощи функции 5ОВЗТВТМС ІМРЕХ (см. главу 5): 


ОРРАТЕ ту сопёасіѕ 
ЗЕТ іпіегеѕё1 = ЗОВЗТАТМС ТМОЕХ (іпіегезёв, ',', 1); 
7 Г < 


Имя искомый „Поиск 
После выполнения команды таблица силолдиа. символ первого 
будет выглядеть так. (заияилая). вхождения. 
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Разделение увлечении 


А теперь самое сложное: мы воспользуемся другой функцией для 
удаления из текущего значения іпбегеѕіѕ данных, скопирован- 
ных в столбец іпіегеѕі1. После этого можно будет продолжить 
заполнение остальных столбцов по тому же принципу. 


Г ме | мен [ мена | Бениз | гена | 
одйудвв,тричтьве [9 | 


ыы 
9 Мы удалим илексил первого увлечения, следу - 
ющию за ним запямлую и пробел, следующий 
за заляилой 8 силолбие <<илфеге$$». 


Функция ЗОВЗТЕ получает текст столбца 1п1егезе$ и возвращает 
заданную его часть. Мы выделяем символы, которые были скопи- 
рованы в іпіегезі1, а также еще два символа (запятая и пробел). 


Заменииль содержимое силолдца 
пилегесё илем, чило В нем храниился 


сейчас, с удалением символов, ско - И илексила 
лированных В <лЕекеѕЕ1 >>, залямлои доле «игерту "ои еще 2. символа: 
и пробела. } заияилая и пробел. 
ОРРАТЕ ту сопфасе$ с ааа. КА 
ЗЕТ іпбегеѕіёѕ = 50ВЅТКЕ (іпіегеѕёѕ, ГЕМСТН (іпёегеѕі1) +2 ); 
й АВ А В 
Финкция $0В5ТК возвраидаеил часи 21 ЕМСТН 5 
унки нлексила зилого силолдца Функц 0 нашем ириме 
исходног0 и, него первЧЮ бобра 4. лина Сипрок р 
Она ои крчглых скодках, длину силроки, Ч _ 


один» 
часиль, описанную ной ё круглых скобках. равна 4. 


и возврашаеил Вилорчю- қ 
Аулак, счММА будем 
авна 4+2, или © 77 
именно силолеко сим” 
Волов будем чдале- 


Как . бери де ранее радбиила 
некоилорых функций зависиил оил 
используемой разновидносили $01. 
Так Воил, эило одна из илаких функ- в начале силарого 
ций. За описанием вашей конкреил- ае мого силолбиа 
ной разновидносили ЗОЁ обращай- сор | 

илегю к докилленилации И 
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разделение текстовых данных (часть 2) 


Обновление столбцов 


После выполнения команды ОРРАТЕ таблица будет выглядеть 
так, как показано ниже. 

Однако работа еще не закончена. Теперь нужно проделать то 
же самое для столбцов іпіегеѕі2, іпіегеѕі3 и іпіегеѕі4. 


|___Лабеғезіз | Имюгезм | №егем2 | _ іабегәв3 [| іһеғезб 
аиы | он 1р 


г. Возьми в руку карандаш 


е Заполните пропуски в команде ирдате. Мы привели пару под- 
. сказок, чтобы немного упростить вашу задачу. 


ч 


Подсказка. С каждым вызо- 
00м 50В5ТЕ илексил силолб- 


ца <<илфегез$ силановиился 
все короче.» 


ОРРАТЕ пу сопфасез ЅЕТ 

— 50ВЅТВІМС ТМОЕХ (іпбегезёѕ, ',', 1), 
іпёегезіѕ 50ВЅТА (іпёегеѕіѕ, ГЕМСТН (іпёегеѕ+1) +2), 
іпђегеѕі2 ЗОВЗТАТМС ІМЮЕХ (- не 

У іпёегезіёз ЗОВОТВ (ааа А 
іпёегеѕіЗ ЗОВУТВТМС ТМОЕХ (....................... се 
іпіегеѕіѕ ЗОВФТЬ (......... ЕЕРЕЕ 
Е Ей анаа о наара нам а МА 

> осилаеился мо - 


следнее, чеилверилое увлечение. Чило с 
ним нужно сделаиль? 


Залолнииле содержимое всех силолбиов 
Ц после выполнения большой команды. 
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Вывод списка 


Наконец-го все увлечения разделены по разным столбцам. Для вывода можно 
воспользоваться простой командой ЗЕТЕСТ — но не для всех одновременно. 

И команда не позволит легко извлечь их в один итоговый набор, потому что увле- 
чения хранятся в четырех столбцах. Результат будет выглядеть примерно так. 


Ее Еай УМпдом Нер ТооМапуСоитп$ 
> ЅЕГЕСТ іпёегеѕі1, іпіегеѕё2, іпіегеѕіЗ3, іпіегеѕё4 ЕКОМ пу сопфасез; 


----------- + 
іпёегеѕіё4 


музыка рыбалка 
живопись 

лошади животные 
музыка спортз 
туризм музыка 
лошади 

музыка 

животные 

собаки 


Конечно, мы можем написать четыре отдельные команды ЅЕІЕСТ для 
вывода всех значений: 


ЗЕТЕСТ іпбегеѕї1 РВОМ ту сопфасез; ЗЕТЕСТ іпбегеѕїі3 ЕКОМ му _сопбасЕз; 


ЗЕГЕСТ 1пеегезе2 ЕКОМ шу_сопфасез; ЗЕТЪЕСТ іпбегеѕё4 ЕВОМ ту сопбасізѕ; 


Остается лишь понять, как вставить результат выполнения этих команд в новую 
таблицу. К счастью, это можно сделать, причем способ не один — их не менее трех! 


Попробуатесами 


Вспомните команду 5Е1ІЕСТ для столбца ргоѓеѕзіоп, написанную нами на с. 375: 


пражнение 


ЅЕІЕСТ ргоЁез51оп ЕКОМ ту сопбасіѕ СКООР ВУ ргоѓеѕѕіоп 
ОБОЕВ ВУ ргоѓеѕѕіоп; 


На следующей странице представлены ТРИ СПОСОБА использования команд $Е1ЕСТ для 
автоматического заполнения новой таблицы іпіегеѕіѕ. 


Поразмыслите над командами 5ЕТЕСТ, ІМЅЕЋТ И СВЕАТЕ. Затем переверните страницу 
и посмотрите описания трех способов. 


Ваша задача — не угадать правильный синтаксис, а обдумать имеющиеся возможности. 
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тройное веселье с запросами 


Дороги, Которые мы Выбираем 


Возможность сделать одно и то же тремя (и более) разными 
способами кому-то может показаться веселой, но нормаль- 
ных людей такое изобилие обычно сбивает с толку. 


И все же это полезно. Зная три решения одной задачи, вы 
всегда сможете выбрать то решение, которое лучше под- 
ходит для ваших потребностей. А по мере роста объема дан- 
ных вы заметите, что некоторые запросы быстрее выпол- 
няются вашей РСУБД. Запросы к очень большим таблицам 
желательно оптимизировать, и умение решать одну задачу 
разными способами вам в этом поможет. 


ед- 
На ближайших силраницах ир 


особа —> 
я ‚ны все мри Си и 
силаблен ноя иладлций! 


| ргобевеќоп | 
ргої іа Ож 


д аи запол 
гозсаний и? | > 
а аАвНЫмМи значениями, цио ет 
иникалено! м 
рядочнными ло алфабии^Ч 


(Почти) одновременное Выполнение СКЕАТЕ, ЅЕГЕСТ и 1М$ЕВТ 
1. СКЕАТЕ ТАВІЕ, затем ІМЅЕКТ с ЅЕГЕСТ 


Этот способ вам уже известен! Сначала таблица саб1е 
создается командой СВЕАТЕ, а затем столбцы заполняются 
значениями, возвращаемыми командой ЅЕІЕСТ на с. 375. 


Создание илаблицы ркоѓеѕѕіст го тлолбцом 


А первичного ключа и силолдиом УАЮСНАК 
СЕ ТАВЬЕ ргоѓезѕіоп =“ а дли описаний Аро 
іа ТМТ(11) МОТ МОШ, АОТО ТМСВЕМЕМТ РАТМААУ КЕҮ ды 
ргоѓеѕзіоп уагсћһаг (20) 


); 


ТМ5ЕВТ ІМТО ргоѓғезѕіоп (ргоҒеззіоп) 
ЅЕЦЕСТ ргоѓеѕѕіоп ЕРКОМ шү сопёасі& 
СВОПОР ВУ ргофезз1оп 


ОВРЕВ ВУ ргоҒеззіоп; 
Р қ Заполнение силолбиа <«ргоесвгои» 


иладлицы ргоез$гои значениями, 
быдаваемыми командой ЅЕ ЕСТ: 
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СКЕАТЕ ТАВІЕ с ЗЕТЕСТ, добавление первичного Ключа Команцой АІТЕВ 


Второй способ: таблица ртоЁеззтол создается командой СВЕАТЕ с ис- 
пользованием даипых команды ЗЕБЕСТ, возвращающей значения столбца 
ргоѓеѕѕзіоп таблицы ту _сопфасез. Затем таблица изменяется командой 


АЦТЕК с добавлением первичного ключа. С. 
оздание илаблицы ро 551 
гогез$от с единсил - 


__ венным силолбиом. Тадлица заполняеился 


значениями, поличеннь 5 
СВЕАТЕ ТАВЬЕ ргоҒеѕѕіоп аз ў Иол 


ЅЕТЕСТ ргоЁҒеѕѕіоп ЕВОМ шу сопёасёѕз осле чего коман 

СКООР ВУ ргоҒеѕѕіоп 27 да АТЕВ добавляет 

ОВРЕВ ВУ ргоѓеѕѕіоп; 6 иладлииу силолдец 
АГТЕВ ТАВІЕ ргоЕезз1оп первичного клкоча. 


АБР СОГОММ іа ІМТ МОТ МОМ, АОТО ТМСВЕМЕМТ ЕТВ$Т, 
АБР РБІМАРВҮ КЕҮ (іа); 


Одновременное Выполнение СКЕАТЕ, ЅЕІЕСТ и ІМЅЕКТ 


3. 


ЧАИ 


СКЕАТЕ ТАВІЕ с первичным Ключом и ЗЕТЕСТ 6 одной Команде 


А этот способ состоит всего из одного шага: команда СВЕАТЕ созда- 
ст таблицу ргоГэзатоп со столбцом первичного ключа и столбцом 
УАВСНАК для хранения профес ий, одповремепно с заполнением 
последиего данными запроса ЭВЕРЕСТ. Условие АОТО ІМСКЕМЕМТ 
сообщает РОУБД, что значения столбца іа должны геперироваться 
авгомагически, а следовательно, дапные будут направлены в един- 
ственный оставшийся столбец. 


Создание ила 
блице реоѓеѕѕіои 
с первичным клю- 
чом и стлолдцом 
‚ «<ргоѓеѕеи >, коило 
СВЕАТЕ ТАВІЕ ргоҒеѕѕіоп С рой немедленно зе 
( ра долнявилея данным 4 
іа ІМТ (11) МОТ МОМ, АОТО ТМСВЕМЕМТ РЕТМАВУ КЕУ, ЗЕЁЕСГ 
ргоѓҒеѕѕіоп уагсраг (20) 


) АЗ / 
ЗЕГЕСТ ргоѓезѕіоп ЕКОМ пу сопёасёѕ а" А е 
18 „а 
Е. 


СВОЦПР ВУ ргоЁЕе$$1оп а 
ОВОЕВ ВУ ргоЁЕезз$1оп; 


Я еще не видел ключевое слово А5. 
Похоже, оно используется для обозна- 
чения результатов запроса, вставляе- 
мых в новую таблицу. 


Да, ключевое слово А$ делает именно это. 


Опо использустся при определении псевдонимов, 
которыми мы сейчас займемся! 
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ключевое слово 45 


Зачем нужно А$? 


А5 заполняет новую таблицу результатами 5ЕТЪЕСТ. Таким образом, 

при использовании А$ во втором и третьем примерах мы указываем 
РСУБД, что данные, полученные из таблицы ту сопёасёѕ в резуль- 
тате выполнения ЅЕІЕСТ, следует поместить в только что созданную 


таблицу ргоѓеззіоп. 
Если ды мы не создали 


Если бы мы не указали, что новая таблица содержит два столбца с но- илабли цу с двумя сил 5 
выми именами, то условие А$ создало бы всего один столбец с таким ПАМИР Е Е олб- 
же типом данных и именем, каку столбца из команды ЅЕІЕСТ. здала бы одун р. 

ц 


Создаем в но с маким же илипом дан - 


Вой илаблице ных и именем, как 
Силолбец улила СВЕАТЕ ТАВІЕ ргоѓеѕѕіоп 9 резульилаила ЅЕГЕСТ. 


УАВСНАВ ( 
с именем іа тмт (11) мот МЛІ АОТО ТМСВЕМЕМТ РЕВТМАКУ КЕУ, 
РгоЁе5вгои. ргоҒеѕѕіоп уагсһаг (20) 


) АЗ 
Эило короилкое 2А ЅЕГЕСТ ргоҒеѕѕіоп ЕВОМ ту сопбасёѕ 
ключевое сло ба СВОЧР ВУ ргоѓғеѕѕіоп = 
играеил Важну в ОВРЕВ ВУ рго#ез51оп; < Все эили имена оил - 
носяился к силолбцу 


оле: оно наира?” | 
явил весь вывод <«риоЁез5тот> илаблииы 


СЕГЕСТ 6 новую илу_соиЁдсіс. 
илаблииу: 


Так как таблица ргоѓеѕѕіоп была создана с автоматически 
увеличиваемым первичным ключом, значения могут добав- 
ляться только во второй столбец таблицы, которому также 
присвоено имя ргоѓеѕѕіог. 


Я совсем запуталась — «ргоѓеѕѕіоп» встреча- 
ется в этом запросе целых пять раз! Возможно, 
РСУБД отличает одно вхождение от другого, 
но как их различу я? 


Для предотвращения путаницы столбцу 
можно назначить альтернативное имя. 

Это одна из причин, по которым 501. позволяет 
назначать столбцам и таблицам временные имена, 
называемые псевдонимами. 
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Псевдонимы столбцов 


Создать псевдоним очень просто. Он указывается после первого использова- 
ния имени столбца в запросе с другим ключевым словом А$. Оно сообщает 
РСУБД, что столбец ргоѓёеѕзіоп таблицы ту сопбасіз может временно 
называться новым именем, чтобы пользователю было проще разобраться 


в происходящем. 


Мы присвоим данным, выбранным из таблицы ту сопёасі5ѕ, имя вс ргоЕ 
(тс — сокращение от ту сопёасізѕ). 


СКЕАТЕ ТАВІЕ ргоЁЕе$$1оп 


( 
іа ІМТ(11) МОТ МОБЬ АОТО ІМСКЕМЕМТ РЕТМАВУ КЕҮ, Эилоил запрос 
_ Зелаеил ило же 


ргоЕез51оп уагсћаг (20) 
самое, но благо - 


) АЗ 
ЅЕГЕСТ ргоѓеззіоп АЅ шс ргоЕ ЕВОМ шу сопіасёзѕ аи я псебдониму 
| ироще 
СВООР ВУ вс рго# =— а Разоволаые. 


ОКЕЕВ ВУ шс_ргоЕ; <, Укажииле исевдоним после 
первого использования исход 
ного имени силолдца в заиро- 
се. Тем самым вы сообщаеиле 
своей РСУБД, чило в дальней - 
ем к силолдиц Возможны об- 
Ращения не илолько по имени 
НО и ио исевдоними. 


Между двумя запросами существует одно неочевидное различие. 
Все запросы возвращают результаты в форме таблиц. Псевдоним 
изменяет имя столбца в результатах, но не изменяет исходного име- 
ни столбца. Иначе говоря, псевдоним действует временно. 


Но так как мы указали, что новая таблица состоит из двух столб- 
цов (первичный ключ и столбец ргоЕе$$1оп), столбцу таблицы 
будет присвоено имя ргоЁе55$1оп, анетс ргоѓ. 


Резчльилаилы - 
5 Резульилаиле! Арвад В 
исходного за- | иа" 


его исе 
ее шего псевдоним 


ргодгаттег 
їеасһег 


ргодгаттег 


А Имя сю - Г вме | 
ходным именем И/МЯ силолдца со Буда 
АА падаеил с псевдо – 
аи нимом. 
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псевдонимы таблиц 


Кому нужны псевдонимы таблиц? 


Вам и нужны! Мы сейчас займемся соединениями с выборкой дан- 
ных из нескольких таблиц. Без псевдонимов вам придется вводить 
имена таблиц снова и снова и вам это быстро надоест. 


Псевдонимы таблиц создаются почти так же, как псевдонимы Пеевдонимы 
столбцов. Псевдоним таблицы указывается после первого 
использования имени таблицы в запросе с ключевым словом А5. таблиц также 
В следующем примере оно сообщает, что таблица ту сопёасїѕ 
в дальнейшем будет также доступна по имени тс. называются 
ЅЕІЕСТ ргоҒеѕѕіоп А$ шсргоЕ параллельными 
ЕВКОМ ту сопбасіёѕ А5 тюс именами. 
СВОЧР ВУ тс ргоЕ МИ 
ила 
ОВРЕВ ВУ мс ргоѓ; Псевдоним! | 
Р р созданился илак же, Как 


и исевдониме! силолбиов. 


И я должен а 


каждый раз, когда потребуется 
создать псевдоним? 


Нет, существует сокращенный синтаксис 
назначения псевдонимов. 


Просто не указывайте ключевое слово А$. Следу- 
ющий запрос делает то же самое, что и запрос в 


начале страницы. 
Вы 
Эили два за^р 


са делаюил одно 
и ило же. 


и 


ЗЕБЕСТ ргоЕезз1оп тюс ргоЕ р исевдонима без клю- 
чедого слова АЗ. Псевдоним дол. 


ЕВОМ ту сопіасіёѕ я ож жен указываться сразу же после 
СВООР ВУ тюс ргоЕ имени иладлицы или силолбид, 
ОВРЕВ ВУ шс ргоЕ; с коилорым он связываеился. 
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Все, что Вы хотели знать о Внутренних соединениях 


Каждый, кому доводилось слышать разговоры о ЗОГ,, 
наверняка слышал слово «соединение». Эта тема не так 
сложна, как может показаться на первый взгляд. Мы 
покажем вам, что такое соединения, как они работают, то 
в каких ситуациях их следует при- АК "И 

2: на самом деле берутся 
менять и в какой ситуации приме- 

таблицы результатов. 

няется та или иная разновидность 
соединений. 


Но начнем мы с рассмотрения 
простейшей разновидности соеди- 
нений (которая и полноценным 
соединением-то не является!). 


Она известна под разными имена- 
ми. В этой книге мы будем называть 
се перекрестным соединением, 
хотя также встречается термин 
«перекрестное произведение» и 
«декартово соединение». 


Предположим, имеются две таблицы: с именами детей и названия- 
ми игрушек, которые естьу этих детей. Ваша задача — узнать, какие 
игрушки можно подарить каждому ребенку. 


солдатики 
губная гармошка 
бейсбольные карточки 
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оз 


перекрестные соединения 


Перекрестное соединение 


Результат следующего запроса представляет собой перекрестное 
соединение. Мы запрашиваем данные из обеих таблиц: столбец 
Соу из таблицы воуз и столбец Боу из таблицы Боуз. 
а 
К Помнииле сокращенную запись из предыду- 
М шей главы? Перед плочкой указеваеился имя 
ЅЕІЕСТ Ё.ёоу, Ь.БоуУ маблицы, после мочки — имя силолбца ила- 


ЕВОМ Фоуз А$ Е блииы. Только на эилоил раз вмесило полных 
своѕ$ отм К имен илаблии используюился псевдонимы. 
Ьоуз АЗ Ь; \ Заирос чиилаеил данные из силолбца «оц» 


иладлицы боуѕ и из силолбиа <ф04> илад- 
Здесь иложе исполе- е и Осилавщаяся часиль заиро- 
зуюился псевдонимы а соебиняеил эили два силолбца 6 новую 
илаблицц. 
илаблии. 
Перекрестное соединение создает пару из каждо- 
го значения первой таблицы и каждого значения Перекреетное ©0- 


из второй таблицы. 


р ОРТЕН единение (СКО 
ЈОТМ) возвращает 
комбинации каждой 
записи первой табли- 
лаам обоа иронии сс. ЦЫ 6 каждой запиеыю 


единения. Каждой игрушке силавиился 


8 сооилвеилеилвие каждый мальчик. второй таблицы. 


Резульилаил не содержиил дубликаилов. 


Результат соединения состоит из 20 записей 
(5 игрушек * 4 мальчиков), то есть всех воз- 


можных комбинаций. обруч 


о 

Такая группировка данных дпълсните | обру 
а о илем, ЧИЛО +оуѕ. оч совер П: о 

. оо е замисей. Если ды 6 илабли | Ежа сива 
а е 5 залисей, а 6 илаблице Ч БОЕ 
це <фоу? 4 закиси, ило резулеглбиль ; [-вамолет 
И ров ись бы по именам мальчиков. Е 2588 
рца е чило порядок резульи^аи^о Ба 05а 

отой запроса не имееил значения, [`` самолет | 
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адаБаеМые 


Вось 


ђ: И зачем мне это нужно? 


(} О перекрестных соединениях важно знать, потому 
что при экспериментах с соединениями можно случай- 
но получить перекрестный результат. Это поможет вам 
исправить неправильно написанный запрос. Поверьте, 
такое случается. Кроме того, перекрестные соединения 
иногда используются для тестирования скорости РСУБД 
и ее конфигурации. Их обработка занимает относитель- 
но много времени, что упрощает анализ и сравнения. 


‚ А если использовать запрос вида: 
ЗЕЦЕСТ * РАОМ +оуз СВОЅЅ ЈОІМ Ьоуз; 
Что произойдет при использовании ЅЕ1ЕСТ *? 


(} Попробуйте сами. Вы получите те же 20 записей, 
но в них будут включены все 4 столбца. 


Внугренним еоединением 
(ТММЕК ЈОГА) называетея 
перекреетное соединение, 
из результатов которого 
чаеть записей иеключаетея 
по условию запроеа. 


* Что произойдет при перекрестном соединении 
двух очень больших таблиц? 


(} Вы получите огромное количество записей. С пере- 
крестным соединением лучше не экспериментировать — 
при таком гигантском объеме возвращаемых данных 
ваш компьютер может «зависнуть»! 


|: Существует ли другой синтаксис у таких запро- 
сов? 


() Да, существует. Вместо ключевых слов СКОЅ5 ЈОІМ 
можно поставить запятую: 


ЗЕЪЕСТ ёоуѕ.ёоу, роуѕ.роу 
ЕКОМ ёоуѕ, роузѕ; 


О 

• Ранее я слышал термины «внутреннее соедине- 
ние» и «внешнее соединение». Это то же самое, что 
и перекрестное соединение? 


(} Перекрестное соединение является разновидно- 
стью внутреннего соединения. В сущности, внутреннее 
соединение - это перекрестное соединение, из результа- 
тов которого некоторые записи исключены по критерию 
запроса. Внутренние соединения вскоре будут описаны 
более подробно – а пока просто запомните! 


с МОЗГОВОЙ 
ШТУРМ 


Как вы думаете, какой результат вернет следую- 
щий запрос: 


ЅЕІЕСТ Ь1.Ъоу, 


р2.роу 


ЕВОМ роуѕ А5 Ь1 СКО55 ЈОІМ Боуз Аз р2; 


Попробуйте сами. 


389 
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< Возьми в руку карандаш 


ргої 1а бр 


ргоЁ іа &2==у 


ЅЕТЕСТ мс.1аз® пате, 

юс.Ғігѕё папе, 

р.ргоҒеѕѕіоп 

ЕВОМ му сопфасёз А5 тюс 
ТММЕВ ЈОІМ 
рго#езз1оп АЅ р 


ОМ тс.сопёасі іа = р.ргоЕЁ іа; 


Перед вами две таблицы из базы данных 
дгедѕ 1156: ргоѓеѕѕіопи ту сопбасіз. 
Просмотрите код запроса и запишите, что, по 
вашему мнению, делает каждая строка. 
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Допустим, данные из трех карточек, приведеных ниже, занесены в таблицы. 
Изобразите таблицу с результатами. 


Джоан Эвереили^ 


Не замужем 

4-5-1978 

Соли -Лейк-сиили, ОТ 

Художник ВТР 
з Замужем 

јемегеёеилідёудиилраїїлеѓ 9. © Ў 
парусный спорил, илуризм, кули | 70 
нария | ее: 8.7 
555 555-9870 ЫЕ: 

ж 


ѓага@рееаклескріга.соил 
кино, книги, кулинария 
555 555-5452 


Пол Сингх 


Женаил 
12-10-1980 
Нью-Йорк, МҮ 
Профессор 

м 
рѕ@+ікіредлЇоитде.сомл^ 
собаки, 

555 555-8222. 


бельше +» 391 


возьми в руку карандаш. решение 


Возьми в руку карандаш 


ь< А гешениг 
сұ. 


Перед вами две таблицы из базы данных 
дгедз_ 11зі: ргоѓеѕѕіопи ту сопїасізѕ. 
Просмотрите код запроса и запишите, что, по 
вашему мнению, делает каждая строка. 


сопїасі 1а ор 


Ыігіћаау 


м 
ргої іа «2-е 
21р__соде 


ЅЕТЕСТ тс.1аѕё пате, Выборка силолдца «Їаѕ+ маиле» илаблииы 
И ееины 
шс.Е1гз пате, ‚и сплолдиа «Нүѕё мамле» илаблицы илу соиасёб — 
р.ргоѓеѕзіоп и силолдца «‹ргоѓЃеѕѕіои» иладлицы 

ргофезяои (псевдоним р) 

ЕВОМ пу сопбасёѕ А5 тс из илаблице илу солёасіѕ (псевдоним ис) 
ІММЕВ ЈОІМ внуилреннее соединение резулемларлов выборки 
ргоЕезз1оп АЗ р с плаблицей риоРестои. (исевдоним р) 


ОМ тс.сопбасі іа = р.ргоЕ ій; „ри условии, чило значение силолдиа 


<«сомёасЕ > иладлицы илу сомѓасіѕ со - 


Допустим, данные из трех карточек, приведеных ниже, занесены в таблицы. 
Изобразите таблицу с результатами. 


Нез? пате | _рғойезвіоп | 
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ОтКрой свое Внутреннее соединение 


Понял! Так я могу связать новые табли- 
цы с новой версией ту_сопфас{<. Мне 
не нужно писать десяток ЅЕІЕСТ, доста- 
точно включить таблицы во внутреннее 
соединение! 


Все только начинается 


Думаете, это все? Мы рассмотрели только одну 
разновидность одного типа соединений. И вам еще 
предстоит узнать много всего об этом и других ви- 
дах соединений, прежде чем вы сможете эффектив- 
но и разумно применять их на практике. 


Внутреннее соединение комбинирует записи двух 
таблиц в соответствии с заданным условием. Столб- 
цы включаются в выходной набор только в том 
случае, если соединенная запись удовлетворяет 
условию. Давайте повнимательнее рассмотрим 
синтаксис. 


Силолдиы, колерые 


терот запрос. 
ЅЕ1ЕСТ зомесо1аип$ 
ЕВОМ ёарІе1 < 


ТММЕВ ЈОІМ Мы не указываем исевдо- 
Пр, о Барай 4—7 нию запро К 
клочевое слово “ОМ зопесопаіёіоп; 
НЕВЕ. ИН г. условии могцил исполь- 


зоваилься любые опера- 
илоры сравнения. 


Внугреннее соединение комбинирует 
записи из двух таблиц в соответ- 
етвии е заданным условием. 


дальше » 
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эквивалентное соединение 


Внутреннее соединение 8 действии: эКВисоединение 


Рассмотрим следующие таблицы. У каждого мальчика 
есть только одна игрушка. Связь относится к типу 
«один-к-одному», а соу іа — внешний ключ. 


Боуз 


губная гармошка 


5 бейсбольные 
карточки 


Все, что требуется — определить, какая игрушка принад- 
лежит каждому из мальчиков. Мы можем воспользоваться 


внутренним соединением с оператором = для поиска совпа- эквивалентное соеди- 
дений внешнего ключа роуѕ с первичным ключом +оуз. 

нение — внутреннее 
соединение с проверкой 
равенетва. 


ЅЕІЕСТ Боуз.Боу, ёоуѕ.іоу 

ЕВОМ Боуз 
ІММЕК ЈОІМ 
+оуѕ 

ОМ Ьоуѕ.іоу іа = іоуѕ.іоу іа; 


Бобби 


Ричи бная гармошка 


бейсбольные 
‹арточки 


Иилоговая илабли - 
цо. При желании в 
залрос можно было су 
добавииль условие 


ОВрЕК ВУ боу.004. е 
САБЫ бейсбольные 


карточки 
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Возьми в руку карандаш 


К Напишите следующие запросы эквивалентных соединений 
к. для базы данных дгедѕ 1ізі. 


Запрос, который возвращает адреса электронной почты (ета11) и профессии (ргоЁЕезз1оп) каждого 
человека в ту сопіасіз. 


Запрос, который возвращает имя (їігѕ‹_ пате), фамилию (1аз® пате) и семейное положение (зёаё из) 
каждого человека в ту сопібасізѕ. 


Запрос, который возвращает имя (Ёігэс пате), фамилию (1аѕї пате) и штат (5 а{е) каждого чело- 
века в ту сопіасіз. 


[ опись іпїегез? | 


0+» 

0+х 

0+х 
ѕеекіпо_іа «ур 

0+х 


сопіасі_ 19 бе 


рго? 1а 0== 


[аѕї пагле 


Ее [беге | 


іпіегеѕ_ 1а О 


$ ргої 1а = 
2ір_соде = 
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возьми е руку карандаш. решение 


„ Возьми в руку карандаш 
е Решение Напишите следующие запросы эквивалентных соединений 


а. для базы данных дгедз 1ізѕі. 


Запрос, который возвращает адреса электронной почты (ета і 1) и профессии (ргоЁезз1оп) каждого 
человека в ту сопіасі з. 


ЅЕГЕСТ илс.еилай, р.ргоѓеѕѕіол ЕВОМ илу_соиасй$ илс 


ІММЕВ УСМ ргоѓеѕѕіои р ОМ ис.рғоЁ іа = р.ргоЁ іа; в А 
нений ключ рүоР (д связы - 


Ваеился со Силолбцом «рео га» 
иладлицы рүоѓеѕсіоу. 


Запрос, который возвращает имя (Ёі г5е пате), фамилию (1аѕї пате) и семейное положение 
(эСаёизѕ) каждого человека в ту сопіёасіз. 
ЅЕГЕСТ илс.ЁїүѕЕ мдиле, илс.(аѕЕ маиле, в.56афи$ ЕКОМ илу_соифас{$ илс 


ІММЕВ ЈОІМ сѕідёиѕ $ ОМ илс.ѕёаїиѕ І4 = <.5Ёаиѕ (4; | 
Внешний ключ сЕаиѕ 14 
связываеился со силолдцом 
«<сРа+иѕ 4» илаблице! «ёаёиѕэ. 


Запрос, который возвращает имя (Ёігѕї пате), фамилию (1аз пате) и штат (ѕіабе) каждого чело- 
века в ту сопбасіз. 


ЅЕГЕСТ илс. маиле, илс.(а5+ маиле, 2.ъаъе РКОМ илу соиасіѕ илс 
ІММЕЕ УСМ 21р_сойе 2 ОМ илс.21р_соде = 2.21р содае; 
| На эилоил раз в качесилве ключа, 


связывающего две илаблицы, 
используетлся силолбец «21р соде». 


0+ 
0+я 
0+х 
0+х 


сопіасі іа 0 
7 


рго? іа Ож 


ШН] оар 


Ѕ(аїиѕ 1а «ур 
– 


іпќегеѕї_ іа Од 


__зеекіпд | 
еекіпо 1а Ож 
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Внутреннее соединение В действии: неэКВиВалентное соединение 


Неэквивалентное соединение возвращает записи, у которых задан- 
ные значения столбцов не равны. Для примера рассмотрим те же две 
таблицы, роуз и соуз. Используя неэквивалентное соединение, мы 
можем точно узнать, каких игрушек нету каждого из мальчиков (та- 
кой результат более удобен при поиске подарка на день рождения). 


ЗЕБЬЕСТ Боуз.Боу, ёоүѕ.іоу 


ЕВОМ Боуз Операилор <не равно» = 
ТММЕВ ЈОІМ /7 О/лснда и название соеди - 
Упорядочение фоу5 Ц 


/ 
резулотамов у ОМ роуѕ.іоу іа <> іоуѕ.їіоу іа 


циросилиил их 


олив ОКОЕВ ВУ Ш 
Роуз 


б 
Гай 

о 

< 

и 


обруч 


самолет 


солдатики 
губная гармошка 


бейсбольные 
карточки 


обруч 
солдатики 
губная гармошка 
бейсбольные карточки 
солдатики 
губная гармошка 
обруч 
самолет 
обруч 
самолет 
губная гармошка 
бейсбольные карточки 
самолет 
солдатики 
губная гармошка 
бейсбольные карточки 


Чеилыре игру\чки, 
коилорых еще нейл 
= у Бивера. 


Неэквивалентное 
еоединение про- 
веряет нееовпа- 
дение значений. 
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естественные соединена», 


Последнее Внутреннее соединение: естественное соединение 


Осталась всего одна разновидность внутренних соединений — так называемые 
естественные соединения. Естественные соединения возможны только в том 
случае, если столбец, по которому выполняется соединение, имеет одинаковые 
имена в обеих таблицах. Давайте еще раз рассмотрим эти две таблицы. 
Одинаковые имена 


Силолбца. 
Боуз У Соуз 


самолет 


солдатики 
бная гармошка 


бейсбольные 
карточки 


Каки прежде, мы хотим знать, какая игрушка есть у каждого 
из мальчиков. Естественное соединение распознает совпа- 
дающие имена столбцов в двух таблицах и вернет соответ- 


ствующие комбинации. 


ЅЕ1ЕСТ Боуз.Боу, іоуѕ.боу 
ЕВОМ Боуз с, 
МАТОВАТ ЈОІМ , 
фоуз; и 
и 


самолет 


солдатики 
губная гармошка 


. 

| 

пон же аний Еетеетвенное соедине- 
ние связывает записи 

но значениям одно- 


и лаве перво - 
го 
нуиреңннего 


самолет 


соединения, — 
эквисоед 
и" 
именных етолбцов. 
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„ Возьми в руку карандаш 


Напишите следующие запросы для базы данных агеа$_115Е сис- 
“9 пользованием естественных или неэквивалентных соединений. 


Запрос, который возвращает адреса электронной почты (ета11) и профессии (ргоЁезз1оп) каждого 
человека в ту сопіасіѕ. 


Запрос, который возвращает имя (Еі гѕ6 пате), фамилию (1азЕ пате) и семейное положение 
(ѕсаі цз), которым не обладает каждый человек в ту сопбасіѕ. 


Запрос, который возвращает имя (Ёігѕс пате), фамилию (1аѕї пате) и штат (5{а{е) каждого чело- 
векав пу сопіасізѕ. 


| вопћас? іптогез? | 
» 0+ 
0х 
| сопѓас? _зеекіпо | 
0+к 
0+х 


рго? 1а Оу 


Іаѕї пате 


#їгѕї пате [ мого 


п{егез{ 1а ог 


етаії! 


хі 


з еекіпо іа 
ге 


геекіпо_0 Ое 
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Возьми в руку карандаш 
< А Решение, Напишите следующие запросы для базы данных дгедз 1іѕі 
К. = 


с использованием естественных или неэквивалентных соединений. 


Запрос, который возвращает адреса электронной почты (ета1 1) и профессии (ргоѓеѕѕіоп) каждого 
человека в ту_сопїасїѕ. 


ЅЕГЕСТ илс.еилай, р.реоѓеѕѕіол ЕКОМ иу сомЁасіѕ илс 


1ММЕК. ЈОІМ ргоѓеѕѕѓіои р; 
Запрос, который возвращает имя (Ёігзё пате), фамилию (1аѕ пате) и семейное положение 
(ѕсасиѕ), которым не обладает каждый человек в ту сопіасіз. 
СЕЁЕСТ ило.ЁїкѕЕ мамле, илс.[аѕЕ мамле, 5.5Едиѕ ЕКОМ илу сомТасіѕ илс 
ІММЕЕ. ЈОІМ ѕёдёиѕ $ ОМ илс.ѕдёиѕ А <> 5.5ЁаЁиѕ 14; 


< 
лля каждого человека будеил создано несколько залисей 


со всеми вариантами семейного положения, с коилорыми 
эзилоил человек не связан мо с̧Ға+иѕ 14. 


Запрос, который возвращает имя (Ёігѕї пате), фамилию (1аѕ пате) и штат (ѕсаёе) каждого 
человека в ту сопѓасіз. 


ЅЕГЕСТ илс.Ни5 паиле, илс. (д5 маиле, 2.5ёаќе ЕКОМ илу_сомтасіѕ илс 


/ 
[ММЕВ ЈОІМ 2ір_соде 2; 
Условие ОМ 8 первом и илреильем запросах не обяза- 


илельно, потому чило имена Внешнего и первичного 
ключей в них совладани. 


Г ту сопїасів | | опіас? Диого! | 


сопіас 1а 9 
0+х 
_ 9 5$ 


_ рғеќезвіоп | 
рго? 1а Ож 


ааа Г љенеғевів | 


іпїегеѕї_10 «у іпіегеѕї_ і О 
о+к 
ыпраау 


сопїасі_іа т 
о Г зезщее | 

ѕеекіпа_іа кр еекіпод_і9 
0+ 


ѕеекіпо 
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+ 
+кто и о ИЗА 


Проведите линию от каждого вида соединения к его описанию. Некоторые 
виды соединений могут соответствовать сразу нескольким описаниям. 


естественное соединение Я возвращаю все записи, у кото- 
рых значение столбца таблицы 
не совпадает со значением столб- 
ца другой таблицы. 


эквивалентное соединение 
Для меня важен порядок соеди- 


нения таблиц. 


переКрестное соединение 
Я возвращаю все записи, у которых 


значение столбца таблицы совпа- 
дает со значением столбца другой 
таблицы, и при этом использую 


Внешнее соединение ключевое слово ОМ. 


Я соединяю две таблицы, содер- 
жащие одноименные столбцы. 


незквивалентное соединение 


Количество возвращаемых мною 
записей может быть равно произ- 
ведению количества записей двух 
таблиц. 


Внутреннее соединение 


Я возвращаю все возможные ком- 
деКартово соединение бинации без проверки условия. 


перекрестное произведение А соєдинаю две таблицы є пре: 
веркои условия. 


Зальше » 401 


кто и что делает? ответ 


‚ СУ 


+кто и ЧТ ДЕЛАЕТ? 


Проведите линию от каждого вида соединения к его описанию. Некоторые 
виды соединений могут соответствовать сразу нескольким описаниям. 


естественное совацненце Я возвращаю все записи, у кото- 
рых значение столбца таблицы 
не совпадает со значением столб- 
ца другой таблицы. 


экбибалентное соединение 
9 Для меня важен порядок соеди- «<. 


7 нения таблиц. об мам будет рост 
Ў сказано 6 глабё т: 
перекрестное совдимение АТ 

МА 


Я возвращаю все записи, у кото- 
рых значение столбца таблицы 
совпадает со значением столбца 


6 другой таблицы, и при этом ис- 
Внешнее соединекйе пользую ключевое слово ОМ. 

Я соединяю две таблицы, содер- 
жащие одноименные столбцы. 


незкВиВалентное Фвдицивние 


Количество возвращаемых мною 
записей может быть равно про- 
изведению количества записей 
двух таблиц. 


Внутреннее сбедїнение 


Я возвращаю все возможные 


декартоВо соединений / комбинации без проверки 
а. условия. 


р Я соединяю две таблицы с про- 
переКрестное произ &дени и: Р 
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соединения и мыоготабличные операции 


Для приведенной ниже схемы базы данных дгедз_113з напиши- 
те запросы $01, возвращающие указанную информацию. 
пражнение р ращающие у у формац 


Напишите два запроса с разными соединениями для получения парных записей из таблиц му _ 
сопёбасёѕи сопіасё іпіегеѕі. 


Напишите запрос для получения всех возможных комбинаций записей из таблиц сопіасї ѕеекіло 
и ѕзеекіпд. 


Получите список профессий людей из таблицы ту сопіасіз, но без дубликатов и в алфавитном порядке. 


сопїасї_іа кд 
0+х 

іпќегеѕї_ іа «е 
0+х 


сопќасї_іа «у 
0+ 


ы 
ѕеекіпо_іа «у 
0+х 


сопїасї іа 0 


ргої іа Ож 


[а5{ пате 


ЕЕ [Иного 


іпїегеѕї іа Ор 


1 


еекіпо_іа О 
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пражнение 
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Для приведенной ниже схемы базы данных охедѕ 115+ напиши- 
те запросы ЗС\, возвращающие указанную информацию. 


|“ошение 


Напишите два запроса с разными соединениями для получения парных записей из таблиц пу _ 
сопїасіёѕ И сопбасї іпіегеѕі. 


ЅЕГЕСТ илс.ЁїкѕЕ маиле, илс.1аѕ+ мамле, сі.їлъегеѕ та ЕВОМ иу солЕасіѕ илс 
1ММЕВ ЈОІМ соифасё іпЁєегеѕ сі ОМ илс.сомёасЕ та = сі.сотЁас+ 1а; 
ЅЕГЕСТ илс.Ни$Е_паиле, илс. (25 маиле, сглифегезе га ЕВОМ илу_соифас$ илс 
МАТОВА ЈОІМ соифасЕ (мегеѕё сі; 

Напишите запрос для получения всех возможных комбинаций записей из таблиц сопеасЕ зееК1п9 

И ѕеекіпд. 
ЅЕГЕСТ * ЕКОМ солёасі <еекид СКО$$ ЈОІМ еекіма: У, 


ЅЕГЕСТ * ЕКОМ сом+ас+ сеекгла, ѕ6екімд; Два слособа выполнения одного 
-—  иерекресилного соединения. 


Получите список профессий людей из таблицы ту сопеасЕз, но без дубликатов и в алфавитном порядке. 
ЅЕГЕСТ р.ргоѓеѕѕіом ЕКОМ илу_соиасё$ илс 


ІММЕВ ЈОІМ ргоЁеѕѕіои р ОМ илс.ргоЁ 1а = р.реоЁ _ 4 аВОЧР ВУ ргоѓеѕѕіои 
ОКРЕК ВУ ргоѓеѕѕіои; 


0х 

ох 

ок 
ѕеекіпо 14 к-у 

0+х 


сопїасї іа ож = 


1а5ї пате 
#г5ї_ пате 


_рғөбезяіоп | 
ргої 1а О 


іпїегеѕі 1а Од 


еекіпо іа О 


Ѕіаќиѕ іа: 
заи іа, | 
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сіро 


Зада 


‹ Можно ли включить в соединение более двух 
таблиц? 


О 
(} Можно, но об этом чуть позднее. Пока нас интересуют 
только общие концепции соединений. 


ГЈ > > 
| Вроде как соединения считаются сложной темой? 


() С псевдонимами и соединениями запросы $81 все 
меньше напоминают текст на естественном языке. В со- 
кращенной записи (скажем, при замене ключевых слов 
ТММЕК ЈОІМ запятыми) они выглядят еще более запутан- 
ными. По этой причине в книге в основном используются 
более понятные, а не более компактные запросы. 


Встроенные запросы? 


ВаеМые 


Вәлјсы 


соединения и многотабличные операции 


; Значит ли это, что существуют другие варианты 
синтаксиса внутренних соединений? 


(} Да, существуют. Но если вы поймете описанный нами 
синтаксис внутренних соединений, разобраться с другими 
будет намного проще. Сами концепции намного важнее, 
чем тонкости использования ИНЕБЕ или ОМ. 


; Вы использовали в соединении конструкцию 
АРЕА ВУ. Означает ли это, что в соединениях можно 
использовать и другие конструкции? 


(} Да, в соединениях можно использовать конструкции 
СВООР ВУ, ИНЕВЕ, а также функции 50М, А\С ит. д. 


Грег постепенно начинает понимать возможности соединений. 
Он видит, что разбиение базы данных на таблицы имеет смысл, 

а работать с хорошо спроектированными таблицами не так уж 
сложно. Грег даже планирует расширить базу данных дгедѕ_ 115+. 


Но мне по-прежнему часто приходится 
вводить один запрос, а потом использовать 
его результаты на входе другого запроса, 
хотя удобнее было бы разместить один запрос 
внутри другого. Но это только мечты... 


Запрос внутри другого запроса? 
Такое возможно? 


405 
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откровенно о псевдонимах 


ОТКРОВЕННО 
о ПСЕВДОНИМА 
ТАБЛИЦ И СТОЛБЦОВ 


Интервью недели: 


Что они скрывают? 


Неаа Еігѕї: Добро пожаловать, Псевдоним 
Таблицы и Псевдоним Столбца. Мы рады, 
что вы сегодня с нами. Надеемся, вы поможе- 
те нам прояснить некоторое недопонимание. 


Псевдоним Таблицы: Еще бы, я тоже очень 
рад. И вы можете для краткости называть нас 
ПТ и ПС во время этого интервью (смеется). 


Неаа Еігѕќ: Ха-ха! Да, это будет уместно. 
Итак, ПС, начнем с вас. Для чего такая се- 
кретность? Вы что-то пытаетесь скрыть? 


Псевдоним Столбца: Вовсе нет! Если уж на 
то пошло, я стараюсь все прояснить. Ведь 
я сейчас говорю за нас обоих — верно, ПТ? 


ПТ: Конечно. В случае ПС и так понятно, 
что он старается сделать: он берет длинные 
или избыточные имена столбцов и упрощает 
работу с ними. Просто для удобства. Кроме 
того, он предоставляет таблицы результатов 
с понятными именами столбцов. Со мной 
дело обстоит немного иначе. 


Неаа Еігѕќ: Надо признать, мы не настолько 
хорошо знакомы с вами, ИТ. Мы видели, как 
вы работаете, но еще не до конца понима- 
ем, что именно вы делаете. Ведь когда вас 
используют в запросах, вы не отображаетесь 
в результатах. 


ПТ: Да, это правда. Но по-моему, вы не улавли- 
ваете моего более высокого предназначения. 


Неаа Еігѕї#: Высокого предназначения? Инте- 
ресно, продолжайте. 


глава 8 


ПТ: Я существую для того, чтобы упростить 
написание запросов. 


ПС: И еще ты помогаешь мне в соединениях, 
ПТ. 


Нега Еігѕ: Ничего не понимаю. Может, при- 
ведете пример? 


ПТ: Давайте рассмотрим синтаксис. Думаю, 
вам будет предельно понятно, что я делаю: 


ЅЕГЕСТ тс.1аѕ пате, мс.Ё1гзЕ пате, 
р.ргоЕез51оп 


ЕВОМ ту сопёасіѕ А5 тс 
ІММЕК ЈОІМ 
ргоЁезѕѕіоп АЗ р 


ИНЕКЕ тс.сопёасї іа = р.іа; 

Неаа Е!г${: Понятно! Повсюду, где мне при- 
шлось бы вводить ту сопбасіёз, достаточно 
ввести тс. А ргоѓеѕзіоп заменяется нар. 
Так гораздо проще и намного удобнее, когда 
мне приходится включать два имени столб- 
цов в один запрос. 


ПТ: Особестшо когда таблицы имеют похожие 
имена. Упрощепие помогает не только на- 
писать пужный запрос, но и понять сго, когда 
вы вериетссь к пему через какое-то время. 


Неаа Еїгѕ: Большое спасибо, ПТ и ПС. Нам 
было очень... э.... куда они пропали? 


соединения и мнозотабличные операции 


Новые инструменты 


После главы 8 вы можете строить соединения, 
как настоящий 501 -профессионал. Ниже 


перечислены основные понятия этой главы. 
Полный список инструментов приведен 
в приложении ІІІ. 


Перекрестное соединение 


Набор всех комбинаций 
залисей одной илаблицы 

с записями другой пла- 
блицы. Также всилреча- 
ютлся другие названия — 
<декарилово соединение», 
«декарилово произведе - 
ние» и др. 


Естественное соединение 


Внуилреннее соединение 
9е3 «ОМ». Рабоилаеил 
Илолеко ири соедине- 
нии двух илаблиц, со- 


держащих одноименные 
силолдцы. 


эквивалентное и неэкви- 


валентное соединение 


Две разновидносили вну- 
илренних соединений. Эк- 
виваленилное соединение 
возвращаеи^ комбинации 
с равными значениями, 
д неэквиваленилные — 

с неровными значениями 


силолбиов. 


ЭЗальше + 
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=. Возьми в руку карандаш 


“ АНГА Вы уже умеете пользоваться командой А!ТЕВ; создайте в табли- 
еа. Со с. 378 це ту сопіасіѕ четыре новых столбца. Присвойте им имена 
у А іпёегеѕі1, іпіегеѕіё2, іпіегеѕіЗ и іпіегеѕі4. 


АІТЕЕ ТАВІЕ илу солёасёѕ 
АРр (іл+егеѕЕ1 УАВСНАК(20), ифеге52. МАВСНАВ(20), 
ілЕекеѕЕ5 УАВСНАК(20), ілёегеѕ 4 МАРСНАРВ(20)); 


«ВОЗЬМИ в руку карандаш 


Решение Заполните пропуски в команде ирдаќе. Мы привели пару под- 
69 Со с. 380. сказок, чтобы немного упростить вашу задачу. 


Не иуилайиле ЅОВЅТЕІМа 1МРЕХ с $085Т8: функ- 
ция 50В5ТЕІМа ІМРЕХ ищеил заданный илексил 
(6 данном случае запяилую) *внцилри* силолд- 
ца «<іпёегеѕёѕ» и возврашаеил все предиесилвую - 
„щие символы. Функция $0В5Т усекаеил силолдец 
«лете» до илексила, следующего за первым чв- 
ОРОАТЕ шү сопёасёз ЅЕТ | доцением, заляилой и пробела (+2) до конца силроки. 


іпбегезё1 = ЗОВЗТАТМС ТМОЕХ (іпбегезіз, ',', 1), У, 


зпеегезЕз = ЗОВЗТВ (іпіегезіз, ІЕМСТН (іпёегезі1) +2), 


іпёегезё2 = ЗОВЗТАТМС ІМЮЕХ( 6655, ',, 1 у 


іпёегеѕзіз 


іпіегезіЗ 


іпіегезізѕ 


іпёегеѕзі 4 


После удаления первых илрех увлечений из силолбца 
После Вылолнения «алеге» осилаеился илолько чеилверилое ивлече 


команды ооАдСА ние. Эила команда иросило переносиил его 8 новый 
<«ифеутезез» осилается силолдец, Также Вмесило эилого можно было пере 
иусилым. именоваиль силолбец «іл+егес+сэ» в ааа 
\ 
[| Маюезн | мөгез | 
асана оаа 


| Лаоғеві2 | _аногезаз | Імегевіад | 
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9 [|элзапросы 


+ 
+ Запросы внутри запросов * 


И все заметят, что 
я полна... (Как это называется? 
Утонченность? Изысканность? 
Элегантность?) 


Мне, пожалуйста, запрос из двух частей. Соединения — хоро- 
шая штука, но иногда возникает необходимость обратиться к базе дан- 
ных сразу с несколькими вопросами. Или взять результат одного 
запроса и использовать его в качестве входных данных другого 
запроса. В этом вам помогут подзапросы, также называемые подчинен- 
ными запросами. Они предотвращают дублирование данных, делают 
запросы более динамичными и даже помогут вам попасть на вечеринку 
в высшем обществе. (А может, и нет — но два из трех тоже неппохо!) 


за работой к 2регу! 


Грег берется за поиски работы 


До настоящего момента база данных агедз 113% была 
сугубо бескорыстным делом. Она помогала Грегу подби- 
рать пары для своих друзей, но заработка не приносила. 


Внезапно Грег сообразил, что он мог бы открыть соб- 
ственное кадровое агентство, в котором подбирал бы 
людям из своего списка различные варианты работы. 


Имея новые функциональные 
возможности, я могу создать собст- 
венное кадровое агентство! 


Грег знает, что для знакомых, которые заинтере- 
суются его предложением, в базу данных придется 
добавить новые таблицы. Вместо того чтобы раз- 
мещать информацию в ту сопбасіѕ, он решает 
создать отдельные таблицы со связями «один-к- 
одному» по двум причинам. 


Во-первых, не все участники списка шу сопёасёѕ 
заинтересованы в его услугах. Отдельная таблица 
позволяет избавиться от значений МО11, вту _ 
сопіасіз. 


Во-вторых, если когда-нибудь [рег наймет людей, 
которые будут помогать ему вести бизнес, инфор- 
мация о доходах может оказаться конфиденциаль- 
ной. В этом случае Грег предоставит доступ к та- 
ким таблицам только тем, кому он действительно 
необходим. 
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В списке Грега появляются новые таблицы 


Грег добавил в свою базу данных новые таблицы для хране- 
ния информации об ожидаемой должности и диапазоне 
заработка, а также текущей должности и заработке. Также 
Грег создает простую таблицу для хранения информации об 
имеющихся вакансиях. 


Текуихая Исколмая з силчиные 
ыы иаекомая оддо До 9 
рабоила. м вакансии. 
у 
сопќасі і 0==ғ сопќасі Іа Ож јор іа О 
&2— 2 > 


5 
зару 10% 
Ѕ{агї_даїе ѕаіагу Кап 


ауаНаЫе 
уеагѕ ехр 


е 


_сопћасі Їпђеғев? 


а «у 
о+я 
сопіасї_ іа О іпїегеѕі_ іа ку 
__рғоќевзіоп | 
рго 19 Ож |а5{_ пате 0+х 
1а 
+ 


1пїіегеѕї 1а О 


\ таблицы 


[гой ож ли 


шы Гсоптас звекіну | 
Г реа | тай рента 
а 
Зете о 
мы 
ого 19 8 ѕеекіпа іа «= 
——- 0+х 


[ зазкіәә 
КӘ | г епо 0 


старые таблицы 
| 
о 
о, 
> © 
м 
и 
о 
= 


21р соа 


т 


а. 


5іаїиѕ 1 


Так как каждая из двух новых таблиц связана 
сту сопіасіз связью типа «один-к-одному», 
для получения данных очень удобно исполь 
зовать естественные соединения. 


дальше » 411 


ГЕИ Т н 


исп 


Грег исполоз\ё 


формаци 
ов на 
аденис, поскольку в 


ремиальные. 


Грег получил ин 
тае 
найти наилуч 


кандидата он получит п 


Когда Грег найдет не 
жет обзвонить их ип 
Но сначала нео 


веб-раз 


412 


ользование внутрен" 


тся найти кандидат 
шее совп 


шивающих не более 


его соединения 


т Внутреннее соединение 


ой вакансии и теперь пы- 


ю об отличн 
ных. Он хочет 


нее в своей базе дан 


Требуется: Веб-разработчик 


Компан 
ОЕА Е на работу веб-разра- 
для работы Е УСЕЕВ НТМІ, & С5$5 
зайна. о визуального ди- 
Моруа И хорошо разбирающе- 
аа дартах, предоставляется 
в чрезвычайно можность проявить себя 
горой а компании, 
свое дел ят умные люди, любя 

о. щие 


Зарплата: 595 000-510 5000 


Опыт работы: 5+ лет 


к ндидатов, он смо- 


д ьнейший отбор. 
ув базе данных всех 
-аботы не менее > 


скольких 
ровести 
бходимо найт 


аботчико 
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‚ Возьми в руку карандаш 


подзапросы 


Напишите запрос для выборки из базы данных кандидатов, 
= удовлетворяющих поставленным условиям. 


іоЬ Чеѕіғей 
сопѓасі іа == 
е, 


${аг{ ааїе 


Наименымая зарилайла, 
на которую согласен 
кандидаил. 


Зарилаила, комлорую 
кандидаил надееился 
иполучаиль на новой 
радоиле. 


іоь 1з11па5 


јоБ іа О 
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два запроса за два шага 


Но он хочет опробовать другие запросы 


Пока у Грега больше вакансий, чем претендентов. Он намерен прове- 
сти поиск по таблице ргоѓеѕѕіопѕ и выяснить, удастся ли ему найти 
совпадения для открытых вакансий. Далее он собирается выполнить 
естественное соединение с таблицей ту сопіасіз, получить контакт- 
ные данные и узнать, заинтересуются ли кандидаты его предложением. 


Сначала он получает все вакантные должности из таблицы јоБ сиггепї. 


ЅЕТЕСТ &1Е1е ЕВОМ јоЬ 1ізііпдз 


Лишь малая 
<_— Часть должно ~ 

силей 6 илаблице 

Лов_сиггеит. 


а е: | 


СВОЦР ВУ +іё1іе ОВОЕВ ВУ +іб1е; 


Мы используем консилрукицию а 


зуль - 
аЌоур ВУ, чилобы для каж - илаилы. 
дой должнос 


или Возвращала 
се 
илолько одна запись. Кроме 
илого, данные улорядочива - 
№Юился ио алфавиилц, 


«.Б0зьми в руку карандаш 


Напишите запрос для выборки из базы данных кандидатов, удо- 
9 влетворяющих поставленным условиям. 


Нас инилересуюил конилакилные ЕДИР 
7 людей, инлцилих рабои^у веб -разрадоил - 


СЕЁЕСТ илс.[а5 паиле, илс.НузЕ маиле, илс.риопе 


ЕКОМ илу_соиЁасё5 АЅ илс Так как 6 илаблицах Илу. 


6 качесилве первичного 
ключа использцеился 
МАТОВА ЈОІМ —— силолдец «сомфась і», их можно бар при 


оф деѕіғед АЅ ја иомощи есилесилвенного соединения. 


соифасё5 и |об Дезие д 


М/НЕВЕ НЫЕ = 'Веб-разрадоилчик' 


АМР ја.ѕаіагу (ом < 105000; 


“/ Нас инересуютл илолько люди, гоиловые 
ложенную сумму. По силолбиц <«ѕа[аку 1 
илом, чило предложенная зарилаила не 
минимума. 


рабоилаиль за иред- 
ом» мы убеждаемся в 
Ниже запращиваемого 
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подзапросы 


А теперь Грег использует ключевое слово ИМ, чтобы узнать, 
имеются ли кандидаты на эти должности среди его подопечных. 


ЗЕГЕСТ шс.Е1г56 паше, шс.1азе пате, шс.рВопе, с. 61Е1е 


ЕВОМ )]0Ь соггепі АЅ јс МАТОВАТ ЈОІМ пу сопёасёѕ А5 юс 


"НЕВЕ 
)с.+11е ТМ ('Веб-дизайнер', 'Веб-разработчик', 'Официант', 'Парикмахер', 'Повар'); 
Помниие ключевое слово ІМ? С ним запрос ези зулат 


бозбращаеил зались 6 илом случае, если первого запроса. 


значение се входиил В груииц значений 
6 круглых скобках. Рабоилаеил: 


__тме-ршоне | [ене | 
555) 555-8976 
555) 555-4443 
) 
) 


Хиллерман 
Миллер 
Колуэй 


555) 555-5674 |Веб-разработчик 


555) 555-0098 |Веб-разработчик 


Но нам все равно придется вводить два разных запроса... 


у мозговой 
ШТУРМ 


Попробуйте объединить два запроса в один. Запишите здесь этот запрос. 
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знакомство с подзапросами 


Подзапросы 


Чтобы сделать то, что делается двумя запросами, всего в одном запросе, 
нам понадобится включить в него подзапрос. 


Второй запрос, в котором извлекаются совпадения из таблицы 
ргоЁеѕзіопѕ, мы назовем ВНЕШНИМ запросом, потому что в него «упако- 
ван» другой, ВНУТРЕННИЙ запрос. Давайте посмотрим, что происходит. 


ВНЕШНИЙ запрос 


ЗЕТЕСТ юс.Ёігѕё паме, тюс.1аѕє паме, мс.рвопе, јс.бії1Іе 


ЕКОМ јор сиггепе АЅ јс МАТОКАІ ЈОІМ ту сопбасіѕ А5 тс 


у МНЕВЕ 
с. Е Ее 1% (' Р ен: 96 Р , '); 
Эило Внешний запрос к 
и Эили часиль можно удалииль и заме = 

ниуль часилью первого запроса, комо т 

рая силанеил вниилренним запросом. 
Все профессии из списка в скобках были получены в резуль- Подзапрое предетав ЛЯ- 
тате первого запроса — того, который выбирал все вакантные 
должности из таблицы јор соггепі. Таким образом (будьте б Д 

= А Е 

внимательны, это тонкий момент!), мы можем заменить эту ет сооои запрос, «упа 


часть внешнего запроса частью первого запроса. Он по- 
прежнему вернет результаты, перечисленные в скобках, 
но на этот раз будет инкапсулирован в подзапросе: 


кованный» в другом 
запросе. Также он мо- 


ВНУТРЕННИЙ запрос жет называться <вну- 


тренним запросом». 


ЅЕТЕСТ %1Е1е ЕКОМ уор 11561198 <. 
Эила часиль первого запроса 
преврашаеился во Внуилрен ~ 
ний запрос (или подзапрос). 
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ДВа запроса преобразуются В запрос с подзапросом 


Фактически мы всего лишь объединяем два запроса в один. Пер- 
вый запрос называется внешним, а второй — внугренним. 


ВНЕШНИЙ запрос и ВИ" ВНУТРЕННИЙ запрос 


Запрос с подзапросом 


Два объединенных за- 


Роса превращаюился 
запрос с подзаиросом. 


бно" < 
а^006 


ЅЕТЕСТ тюс.ҒігѕЁ паме, шс.1азе пате, шс.рропе, јс.ііб1е 
ЕКОМ јор соггепё АЅ јс МАТОВАГ ЈОІМ му сопіасіѕ АЅ тюс 


ИНЕРЕ јс.біС1е ІМ (ЅЕШЕСТ 61Е1е ЕВОМ јор 1ізііпдѕ); 


Результаты, полученные при выполнении этого 
запроса, в точности совпадают с результатами 
при явном перечислении всех вакансий в условии 


ИНЕВЕ, но набирать приходится намного меньше. Те же результлаилы но всего 


А С одним запросом! 
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урок анатомии 


$. Є под Микроскопом 


418 


Подзапросы: если одного запроса недостаточно 


Подзапрос — не что иное, как запрос внутри другого запроса. 


«Охватывающий» запрос называется внешним, а «вложенный» — внутрен- 
ним запросом, или подзапросом. 


Внешний запрос (иногда называемый 
охваилывающим запросом). 


ЗЕТЕСТ столбец1, апбёћег со1лип 
ЕВОМ +ар1е 


ИНЕВЕ со1ипп = ($ЗЕЪЕСТ со1ллип ЕКОМ +арїе) ; 


Внуилренний запрос (иодзайрос). 


Внешний запрос. 


ЗЕТЕСТ зоте со1зтп, апоћег со1аишп 
ЕВОМ +ар1е 
ИНЕВЕ со1атшп = (ЗЕЪЕСТ солиап ЕКОМ ёар1е) ; 


М. | 
Внуилрен- \ 
нид запрос ЩИ 


Так как подзапрос использует оператор =, он 
возвращает одно значение, одну запись из одного 
столбца (иногда называется «ячейкой», но в ЗО Г, 


используется термин скалярное значение). Это Нам подза ирос 5 м 

значение сравнивается со столбцами в условии ейл скалярное 

ИНЕВЕ. силолоеи, одна : у 
РоеЕ замлела рай: р 


СИАСАВИЯ 


ААД ;а 
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Подзапрое В действии 


Давайте посмотрим, как работает аналогичный запрос к таблице 
пу сопсасіёѕ. РСУБД читает скалярное значение из таблицы 
21р_соае и сравнивает его со столбцами в условии ИНЕВЕ. 


(ЗЕІЕСТ 2ір сое ЕВОМ 


2ір со4е МНЕВЕ сіу = 
'Мемфис' АМО эзфафе = 'ТМ') 


значение 


ЅЕТЕСТ Іаѕі пате, Е1г$е пате 
ЕКОМ шу сопёасёѕ 
МНЕВЕ 2ір соае = (ЅЕІЕСТ 2ір сое ЕВОМ 


2ір соде МНЕВЕ сіїу = 
( 'Мемфис' АМ) збафке 


Запрос Выбираеил из 


ИЛЧ _Соиъасіѕ имена лю - < Часто 
дей, живущих в Мем- Задаваемые 
фисе (илилаил Теннесси). Вопњсь 
: Почему то же самое нельзя сделать с ис- Тот же запрос можно реализовать следующим 
пользованием соединения? образом: 
(; Можно, но некоторые люди считают, что ра- ЗЕТЕСТ 1аѕї пате, Ёігѕї пате 
ботать с подзапросами проще, чем с соединения- ЕКОМ ту соптасіѕ тс 
ми. Хорошо иметь свободу выбора синтаксиса. МАТОКАГ ЈОІМ 21р соде 2с 


ИНЕАЕ 2с.сіїу = 'Мемфис' 
АМр 2с.ѕбабе = 'Т№' 
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беседа у камина 


Беседа у камина 


Внутренний пла внешний? 


Внешний запрос Внутренний запрос 


Знаешь, Внутренний Запрос, ты мне 
вообще-то не нужен. Я прекрасно обой- 


дусь и без тебя. Даи я без тебя обойдусь. Думаешь, это 


так весело — давать тебе конкретный, 
точный результат только для того, что- 
бы ты превратил его в набор подходя- 
щих записей? Количество не заменяет 
качество, знаешь ли. 


Да, конечно. Ты даешь мне один малень- 
кий результат, а пользователям нужны 
данные, и притом МНОГО. Я даю им 
эти данные. Думаю, если бы тебя не 


было, это бы их вполне устроило. 
Нет, я придаю твоим результатам некое 


подобие специализаци. Без меня тебе 
придется возиться со всеми данными 
в таблице. 


Не придется, если добавить условие 


НЕЕ Я И ЕСТЬ твое условие ИНЕБЕ, и при- 


том предельно конкретное. Собственно, 
ты мне не так уж нужен. 


Нужен, еще как. Какая польза от одного 
столбца одной записи? Он просто не со- 


держит достаточной информации. 
р д фор Ладно. Возможно, нам все же стоит 


работать вместе. Я определяю направ- 
ление поиска твоих результатов. 


Конечно, но я работаю сам по себе. 


Каки я. 
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Правила для подзапросов 


Ниже перечислены некоторые правила, которым должны удовлетворять 
пражнение — подзапросы. Заполните пропуски словами из следующего набора (некото- 
рые слова могут использоваться многократно). 


ТОЧКА ( ЗАПЯТОЙ 
ЗЕСТ список стомвцов КОНЕ 


КРУГЛЫЕ СКОБКИ 
ОЕТЕТЕ 


ИРОАТЕ ІМЗЕАТ 


еке 901 

Кодеке 501 Код 0 
Подзапрос всегда представляет Подзапросы могут использо- 
собой одну команду ? ___ ваться в четырех местах за- 


‚ ЗЕІЕСТ 


ии | Подзап могут использо- 
ваться в командах ............ 
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упражнение. решение 


Правила подзапросов 


Помните об этих правилах, когда будете рассматривать примеры подзапросов в этой главе. 


пражнение 
они? 


Кодекс 501 


Подзапрос всегда представляет 
собой одну команду ЅЕІЕСТ. 


Подзапросы всегда заключа- 


ются в КРУГЛЫЕ СКОБКИ . 


Подзапросы не имеют собствен- 


ного символа ТОЧКА 


такой символ обозначает 
КОНЕЦ всего запроса. 


Частро 


Задаваемые 
Воть 


}: Так что же может возвращать внутренний запрос? А как 
е, внешнего запроса? 


‚ В большинстве случаев внутренний запрос может воз- 
вращать только одно значение, то есть один столбец с одной 
записью. Внешний запрос берет это значение и использует его 
для сравнения со всеми значениями столбца. 


: Почему вы говорите об «одном значении», когда в при- 
мере на с. 418 возвращается целый столбец значений? 


: Потому что оператор ТМ просматривает набор значений. 
При использовании оператора сравнения (как = в разделе «Ана- 
томия») имеется всего одно значение, которое сравнивается 
с каждым значением в столбце. 
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Кодекс $01 


Подзапросы могут исполь- 
зоваться в четырех местах 


О 

1: Мне все еще неясно, сколько значений может возвра- 
щать подзапрос — одно или несколько. Что по этому поводу 
сказано в официальных правилах? 


1] 

• В общем случае подзапрос должен возвращать одно 
значение. ТМ — исключение из правила. Обычно подзапросы 
возвращают одно значение. 


. м 

| Что произойдет, если подзапрос возвращает несколь- 
ко значений, но не использует условие ИНЕВЕ с набором 
значений? 


е 
• Хаос и разрушение!.. На самом деле вы просто получите 
сообщение об ошибке. 


рН 


Силолбич «риопе>» 
илаблицы илу_сотёасіѕ 
В резульилаилах на - 
значаеился исевдоним 
<«риопе» и илак далее. 
В общем, вы поняли! 


Правила — это, конечно, хорошо, но я хочу знать, 
как мне избавиться от длинных имен в столбцах результа- 


подзапросы 


тов — таких, как тс.1аѕї_пате. На этот счет есть 
какие-нибудь правила? 


Существует два способа упрощения 
результатов. 

Вы можете определить псевдонимы для своих столб- 
цов в списке ЗЕТЕСТ. Возвращаемая таблица сразу 
становится намного более понятной. 


Вот как выглядит только что осозданный нами подза- 
прос с короткими псевдонимами столбцов. 


Силолбиц <НизЕ мамле» ма - 4 Силолдӧцу <<[аѕё паиле» 
блицы илу_соифасЕ$ 6 резуль- иладлицы Илу _сол+асіс 
илдилах запроса назначаемся назначается псевдоним 


псевдоним К <<[а5лаиле>. се 


ЅЕІЕСТ пмс.Ё1г$Е пате А5 Е1г5&паще, тс.1аѕї пате АЗ 1аѕіпате, 


тс.рһопе А5 рһопе, јс.ёіё1е АЗ јорёіё1е 


ЕВОМ јор соиггепі АЗ јс МАТОВАГ ЈОІМ ту сопіасіѕ (8) те 
—_ 
ИНЕВЕ јореіё1е ІМ (ЅЕ1ЕСТ &1&1е ЕВОМ јор 11$%1п9$); ) 
у Не задывайиле: 


ключевое сло8о 
А$ не являеилея 


одязаилельны м. 


дие, 
Воил КАК Выглядяил резУЛо/ А и и При создании 
озбращаемые С исевдонимами о о вре- псевдонима «гс 
м МІ силолбиов резульма - Бе › Они никак не Влия- можно оиу - 
заир _ илы силали намного а имена использце- Силииль. 


МЫХ ил 
И более моняилными. т аблиц и силолбиов. 


___Везрпате | _ Іазіпате |  рһопе 


Лонниган (555) 555-3214 
(555) 555-8976 
555) 555-4443 


( 
(555) 555-5674 | Веб-разработчик 
В к 


(555) 555-0098 |Веб-разработчик 
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Построение подзапроса 


Самое сложное в подзапросах — не структура, а определение того, 
какую часть запроса следует преобразовать в подзапрос (и нужно 
ли это делать вообще). 


Анализ запросов имеет много общего с решением простых ариф- 
метических задач. Вы находите в формулировке задачи то, что 
соответствует известным значениям (таблицы и имена столбцов), 
и разбиваете сложные утверждения на отдельные компоненты. 


Давайте проанализируем вопрос, который нужно задать базе дан- 
ных, и попробуем преобразовать его в код запроса. 


Кто из моих знакомых 
зарабатывает больше всех? 


Б Я 
Е) Анализ вопроса 
оле 
4 Перефразируем вопрос в контексте таблиц и столбцов базы 


данных. 


«Кто» означает, что вас интересуют столбцы имени и фамилии 
из таблицы ту сопіасіз. «Зарабатывает больше всех» означа- 
ет, что вы хотите определить максимальное значение столбца 
ѕа1агу из таблицы јор соггепі. 


Кто из моих знакомых зарабатывает больше всех? 


а Силолдиы «үс паиле» а. МАХ(5айагу) 


и «аё паиле» иладлицы из илаблицы 
иу соиїдсіс. Јоб сигем. 


Построение запроса, отвечающего на часть вопроса 


Разделим вопрос на части и построим запрос, который возвра- 
щает ответ на одну из частей. 


Похоже, хорошим кандидатом для первого запроса будет выбор- 
ка МАХ (ѕа1агу): 


ЅЕТЕСТ МАХ (за1агу) ЕКОМ јор соггепё; 


Помнииле функцию МАХ? Она 
бозвращаеил наибольшее значение 


из силолдиа, указанного 6 скобках. 
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Продолжаем анализировать запрос. 


С первой частью запроса тоже все ясно; из таблицы 
выбираются столбцы имени и фамилии; 


ЅЕТЕСТ тс.Ғігѕі пате, мс.1азе папе 
ЕВОМ ту сопіасіѕ А$ мс; РА. 


Выборка имени и фамилии. 
Остается понять, как связать эти два запроса. 


Нам нужны не только имена людей из ту сопїасіз, но 

и данные об их заработке для сравнения с МАХ (за1агу). 
Для выборки данных о зарплате каждого человека будет 

использоваться естественный внутренний запрос: 


ЗЕБЕСТ тюс.Ғігѕі пате, шс.1азе_ 
паме, јс.ѕа1агу использование есиле- 
ЕВОМ ту сопёасіѕ АЗ тс силвенного соединения 


Е А б данных 
МАТОКАІ ЈОІМ )оЬ сиггепе А$ јс; о каждого 


человека. 


А теперь добавляем условие МНЕКЕ та часиль, комлорую мы 
для связывания двух запросов. илолько чило написали, 
Мы создаем один большой запрос на выборку, который извлекаеил сведения 
отвечает на вопрос: «Кто зарабатывает больше всех?» о зарабоилке каждого 

2 человека в иладлиие. 


ЅЕТЕСТ шс.Ё1г5® паме, шс.1азе пате Аа с.5а1агу 


ЕКОМ му сопфасез А5 тс МАТОВАГ ЈОІМ јоЬ соггепі АЗ јс 
ИНЕРЕ )с.за1аку = 


(ЗЕГЕСТ МАХ (јс.ѕа1агу) ‚ ЕВОМ о сиггепЕ јс); 


Первая часиль, коилорая силала иодзаиро- 
сом для определения максимального зна 
чения за[агц. Полученное значение исполь т 
зцеился для сравнения с внешней часилею 
запроса для получения резульилаила. 


187000 


Майк? Я так и думал — 
он никогда не проверяет чеки. 


$ 
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Похоже, то же самое можно 
было сделать и без подзапроса. 


Верно, подзапрос — не единственное 
решение этой задачи. 

К тому же результату можно было прийти 

с использованием естественного внутреннего 
соединения и команды ІІМІТ. Как это часто 
бывает в ЗОГ,, задачу можно решить несколь- 
кими разными способами. 


мозговой 
ШТУРМ 


Напишите другой запрос, который покажет, кто из знакомых 
Грега больше всех зарабатывает. 


Мне все равно, 
сколько решений имеет задача. 
Я хочу знать лучший способ. 
Или по крайней мере причины, 
по которым выбирается то или 
иное решение. 


Логично. 


Тогда почему бы вам не обратиться 
к интервью на с. 430? 
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Подзапрос может использоваться в качестве одного из столбцов 


ЅЕ1ЕСТ. Рассмотрим следующий пример. 


ЅЕТЕСТ тюс.Ёігѕё паше, пис.1аз® папе, 


(ЗЕЪЕСТ ѕіаіе 
ЕВОМ 2ір соде 


подзапросы 


= Определяем 
исевдонил для 


МИНЕКЕ шс.21р_ соде = 2ір соае) Аз ѕіаіе ДМИЛЖУДЕОТИА 


ЕВОМ му сопфасе$ тс; 


Наш анализ этого запроса начинается с подзапроса. 
Подзапрос всего лишь устанавливает соответствие 
почтового индекса с обозначением штата по таблице 
21р соае. 


В упрощенном виде запрос делает следующее: 


Перебрать все записи в таблице ту_соптас1<. Для каждой 
записи получить имя, фамилию и штат (для чего запрос 
получает почтовый индекс и сопоставляет его с обозначе- 
нием штата по таблице гір _сойе). 


Не забудьте, что подзапрос может вернуть только одно 
значение, поэтому при каждом его выполнении возвра- 
щается одна запись. Результат выглядит примерно так. 


и | 


Подзапрое, иеполь- 
зуемый в качестве 
выражения столбца 
в команде ЗЕГЕСТ, 
может возвращать 
только одно значение 
из одного столбца. 
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Другой пример: подзапрос с естественным соединением 


Друг Грега по имени Энди хвастается своим замечательным заработком. 
Он не сообщил подробностей, но Грег полагает, что вся необходимая 
информация хранитсяу него в таблице. Он быстро ищет ее, используя 
естественное соединение по адресу электронной почты Энди. 


ЅЕІЕСТ јс.ѕа1агу 


ЕКОМ ту сопбасїіѕ шс МАТОВА ЈОІМ јор соггепі јс Запрос возвращает 
} | <— одно значение — 
ИНЕВЕ ета11 = 'апауёмеаіћегогата.сот'; 
зарилаилу Энди. 


Грег замечает, что запрос возвращает всего один результат. 
Вместо того чтобы получить значение и подставить его 


Эилоил заи ос т в другой запрос, он решает преобразовать его в подзапрос. 
14 Ч руг Рр реоор Р 


деил Внуил 
уилренним. Он пишет один запрос, который: с 6 
использованием опе- 
ь — получает зарплату Энди; Ый" ратора сравнения >. 


— сравнивает ее с другими зарплатами; 


— возвращает имена и фамилии людей, которые зарабаты- 
вают больше Энди. 2 \ 
У коилорых значение «ѕаіауэ? \ 
больше, чем у Энди. 


Запрос получается 
длинным, но он позволит 
мне сравнить значение, 
которого я пока не знаю, 
с другими значениями 
в базе данных. 


Внешний запрос: / 


(ЗДЕСЬ БУДЕТ ЗАПРОС С ЗАРПЛАТОЙ ЭНДИ) 
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НекоррелироВанный подзапрос аи, 
фамилии 
и зарилаилы. 


Итак, все компоненты собраны вое- 
дино; запрос готов. Сначала РСУБД 
однократно выполняет внутренний 
запрос, а затем использует полу- 
ченное значение для вычисления 
результата внешнего запроса. 


РСУБД начинаеил Выполне- 
ние запроса с эилой часили. 


Вывод данных илолеко илех 
людей, у коилорых зарила- 
ила Выше чем у Энди. 


РСУБД обрабаилываеил эили 


два запроса по оилдельносили. Подзамрос полциаетл 


Небольшая часть результатов. Запрос не содер- зарилаилу Энди, коилорая 
жит ОВРЕВ ВУ, поэтому данные не упорядочены. используется внемним Выполняемся 


запросом для сравнения. — первым. 
| мс. Низ пате 


[ела нанә | ісзаіау | 


Автономный подзапрос, 
не содержащий сеылок 


на данные внешнего 
Все подзапросы, которые встречались нам до настоящего 
момента, были некоррелированными подзапросами. запроса, называется 


Внутренний запрос обрабатывается первым, а полученный 

результат используется в условии ЧНЕВЕ внешнего запроса. некоррелированным 
Но внутренний запрос никоим образом не зависит от данных 

внешнего запроса; его можно выполнить отдельно, как само- подзапросом К 
стоятельный запрос. ———=————=5 


Внешний запрос обраба- 

илываеился Вилорым. Его (а если вы произнесеиле — 

е и резульилаилы зависяил оил Слова «некоррелированный 

ВНЕШНИЙ запрос у значения, возврацщенного подзапрос» 6 разговоре, эт 

внутренним запросом. ироизведеил большое вие - 
чаилление на собеседников). 


ВНУТРЕННИЙ запрос 


Внуилренний 
д е запрос не зави - 
Ол внешнего и 


выпол еа 
ёился первым. ыы 
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ОТКРОВЕННО 
ОБ $9. 
Интервью недели: 


Выбор оптимального построения 
запроса из нескольких вариантов 


Неаа Еігѕѓ ЗО: Добро пожаловать, 501. Спаси- 
бо, что не пожалели времени. Мы знаем, что дела 
у вас идут непросто. 


За: Непросто? Теперь это так называется? Я бы 
сказал, что ситуация крайне тревожная, тяжелая 
и плохо поддающаяся объективному анализу при 
крайней запутанности. 


Неаа Р!гз{ 5061: Да уж... Собственно, мы как раз 
об этом. Иногда приходится слышать жалобы 
на вашу чрезмерную гибкость. Когда мы задаем 
вам вопрос, вы даете слишком много вариантов 
ответа. 


З@Е: Действительно, я гибок. Один и тот же 
вопрос мне можно задать разными способами — 
и я дам одинаковые ответы. 


Неаа Еігѕ# $01: Кое-кто считает, что вам не хва- 
тает решительности. 


ЗОЕ: Не стану оправдываться. Вы меня выстав- 
ляете каким-то злодеем. 


Неаа Еігѕ# $01: Нет, мы знаем, что это не так — 
просто вы немного... неточны. 


801: ХА! Я – неточен! С меня довольно. (встает) 


Неаа Еігѕ{ 501: Нет, не уходите. Мы хотим 
всего лишь задать несколько вопросов. Иногда 
вы позволяете нам спрашивать одно и то же по- 
разному. 


З@Е: И что в этом плохого? 


Неаа Еігѕќ $501: Ничего, мы просто хотим по- 
нять, КАК ИМЕННО это нужно делать. Это суще- 
ственно, если ответы все равно одинаковые? 


Ѕасг: Ну конечно, существенно. Иногда мне при- 
ходится очень долго думать, чтобы дать ответ. 
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Иногда БАХ - и ответ готов! Главное — правиль- 
но спросить. 


Неаа Р!г5{ $01: Значит, все дело во времени по- 
лучения ответа? Нужно выбирать из этих сооб- 
ражений? 


ЗОЕ: Ну конечно. Все дело в том, как спросить. 
Я просто пытаюсь ответить на ваши вопросы, 
когда они точно сформулированы. 


Неаа Ғігѕї 501: Скорость? В ней секрет? 


З@Е: Послушайте, я вам подскажу: базы данных 
РАСТУТ со временем. Ваши вопросы должны 
быть как можно проще, чтобы для выдачи ответа 
на заданный вопрос мне приходилось как мож- 
но меньше думать. Задавайте простые вопросы, 
ия быстро отвечу на них. 


Неаа Еігѕї 501: Понятно. А как определить, 
какой вопрос простой, а какой — нет? 


З@Е: Например, перекрестные соединения об- 
рабатываются очень долго. Коррелированные 
подзапросы тоже не отличаются быстротой... 


Неаа Рігѕ ЗО: Еще что-нибудь? 
ОЕ: Ну... 
Неаа ЕР!т5{ $501: Пожалуйста, продолжайте. 


Заг: Экспериментируйте. Иногда лучше всего 
создать тестовые таблицы, опробовать разные 
запросы и сравнить время их обработки. Да, 

и соединения обрабатываются эффективнее под- 
запросов. 


Неаа Ғігѕ# О: Спасибо, 501. Невероятно, 
такая тайна — и вдруг... 


Ѕаг: Ага. Спасибо, что не пожалели моего 
времени. 


подзапросы 


ПРАКТИКА О СПРАЕЛАЯ ЛУАЗ АМРАСОЕ 


Прочитайте каждый из следующих сценариев. Напишите два запроса по приведенным инструк- 
циям, а затем объедините их в запрос с подзапросом. 


\ Грег хочет узнать среднюю зарплату веб-разработчиков в своей таблице јор сиггепї. 
Затем он хочет получить информацию о том, кто как зарабатывает относительно среднего 


уровня. Люди, зарабатывающие менее среднего, могут быть более заинтересованы в поиске 
новой работы. 


Напишите запрос для определения средней зарплаты веб-разработчиков в таблице 
јо сиггепі. 


Грег желает знать имя, фамилию и зарплату каждого веб-разработчика в таблице 
јор сиггепі. 


Напишите запрос для получения имен, фамилий и зарплат всех веб-разработчиков 
в таблице јоЬ сиггепё. 


3 Используя среднюю зарплату (и немного математических вычислений) с подзапросом, Грег 


выводит информацию обо всех веб-разработчиках и о том, насколько больше (или мень- 
ше) среднего уровня они зарабатывают. 


Объедините два запроса. Используйте подзапрос в списке столбцов ЅЕІЕСТ. 
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ПРА\ТАКАУЛАЛАА СТРАЕНАЯ ЛУАЗ АТРАСУЕ 


Прочитайте каждый из следующих сценариев. Напишите два запроса по приведенным инструкци- 
ям, а затем объедините их в запрос с подзапросом. 


у Грег хочет узнать среднюю зарплату веб-разработчиков в своей таблице јор сиггепе. 
Затем он хочет получить информацию о том, кто как зарабатывает относительно среднего 


уровня. Люди, зарабатывающие менее среднего, могут быть более заинтересованы в поиске 
новой работы. 


Напишите запрос для определения средней зарплаты веб-разработчиков в таблице 
јоЬ соггепі. 


ЅЕГЕСТ АМ (ѕаЇағу) ЕОМ јор сиғгемё \МНЕВЕ Не = ‘Вед -разрабоилчик:; 
Е. Среднее значение вычисляеился 
функцией АЎ. 


22, Грег желает знать имя, фамилию и зарплату каждого веб-разработчика в таблице 
јор сиггепі. 


Напишите запрос для получения имен, фамилий и зарплат всех веб-разработчиков 
в таблице јоЬ сиггепі. 
ЅЕІЕСТ илс.ЁїүѕЁ маиле, илс. [аз маиле, јс.ѕа(акч 


ЕКОМ иу солёасёѕ мис МАТОВА ЈОІМ јоб сигем јс 
М/НЕКЕ јс. е = ‘Вед=разрабоилчик" 


3% Используя среднюю зарплату (и немного математических вычислений) с подзапросом, Грег 
выводит информацию обо всех веб-разработчиках и о том, насколько больше (или мень- 
ше) среднего уровня они зарабатывают. 


Объедините два запроса. Используйте подзапрос в списке столбцов ЗЕЦЕСТ. 


Ра , _ Наш подзапрос. 
ЅЕГЕСТ илс. маиле, илс.аѕ паме, Јс.ѕаіағу, К. 


—————————————-——______________——————————————————— 
јс.ѕаіагу — (ЗЕЪТЕСТ АМа(ѕаіағу) ЕКОМ јоб сикғелё МНЕКЕ Ее = 'Вед-разрадоилчик’) 
ЕЕОМ илу_сомЁдсіѕ илс МАТОВА ЈОІМ об_сиигеиЕ јс 

МУНЕВЕ јс. е = "Веб -разрадоилчик"; 
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НекоррелироВанный подзапрос 
в несколькими значениями: №, МОТ ІМ 


Вернемся к первому запросу, который был опробован Грегом на с. 17. Этот 
запрос позволил ему найти людей, должности которых совпадают с одной 
из предложенных вакансий. Запрос берет полный набор значений Е 1%1е, 
возвращаемых командой ЗЕЪЕСТ в подзапросе, и проверяет по этому набору 
каждую запись таблицы јор соггепі для поиска возможных совпадений. 


ЗЕТЕСТ шс.Е1г5е пате, пс.1аѕє пате, тс.рћопе, јс.ііїё1е 
ЕВОМ јор сикгепЕ АЅ јс МАТОКАІ ЈОІМ ту сопіасіѕ Аз мс 
МНЕВЕ јс.іісІе(21М) (ЅЕІЕСТ &161е ЕВОМ јор 1іѕбіпдѕ); 


а Значение се каждой записи проверяется 
мо Всему набору, возвращенному иодзаиросом. 


Ключевые слова МОТ ІМ позволят Грегу отобрать должности, отсутствующие 
среди его вакансий. Эта конструкция берет полный набор значений Е 1Е1е, воз- 
вращенных командой ЗЕЪЕСТ в подзапросе, и проверяет по нему каждую запись 


таблицы ) ор_согкепе. Запрос возвращает все значения, отсутствующие в набо- 
ре. Теперь Грег может направить усилия на поиск вакансий для этих должностей. 


ЗЕТЕСТ тс.Ёігѕі пате, мс.1аз®_ пате, шс.рВопе, јс.іії1е 
ЕКОМ јор сиггепЕ јс МАТОКАІ ЈОІМ ту сопіасіѕ мс 


ИНЕВЕ јс.біє1еСМот ІМ) (ЗЕЪЕСТ ёі1е ЕКОМ јор 1ізїіпдѕ); 


7 МОТ 1м возвращаем должносили, оилецил- 
силвуюшщиє среди предлагаемых вакансий. 


Такие запросы называются некоррелированными под- 
запросами; ключевые слова ТМ или МОТ ТМ проверяют Е 
соответственно присутствие или отсутствие результатов Некор ел ованныи ПОД- 
внешнего запроса среди результатов подзапроса. запрое при помощи І ИЛИ 
мозговой МТ ІМ проверяет факт 
ТРШТУРМ етет аа 
наличия (или отеутетвия ) 
Почему вместо подзапроса нельзя тк 
просто ввести список значений? значении, возвращенных 
подзапросом, в наборе. 
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подзапросы. упражнение 


Напишите запросы для получения ответов на следующие вопросы (используйте соеди- 
нения и некоррелированные подзапросы там, где это уместно). Используйте схему базы 
данных дгедз 11е на следующей странице. 

пражнение В некоилорых запросах должны использоваилься 


агрегаилные финкиии, коилорые рассллаилривались 
нами в задаче о продаже печенья. 


о о 


Выведите все должности с зарплатой, равной наибольшей зарплате из таблицы )о06_113%1п93. 


р А р Ао Чьи, >. > к, 
а > а 
Выведите имена и фамилии людей с зарплатой выше средней. 
(веко ва с. 436. 
о ЕЕ СЕ а 5 0 Е” в а ео 
АЕ И и ЕЕ О ЕЕ Е ИНЬ 
Найдите всех веб-дизайнеров, у которых почтовый индекс (21р_со4е) совпадает с почтовым 
| индексом какой-либо вакансии веб-дизайнера из таблицы )оь_11$1па3. | 
- (зове на с. 431. 
ЕБ ола ее ах де, О аана о А НЕ ТЫ 
Се. РР“ ик а он о ТУ АД 
Выведите список всех людей, у которых почтовый индекс (21р_со4е) совпадает с почтовым 
| индексом человека, получающего максимальную зарплату. | 
(зве на с, 431. 
а ке о, а АЕ, АГЕ НЕ ар. 2 Е о] 


подзапросы 


| юЬ_ сыгғепї іоь _Чеѕігеа ЇоЬ Пїенпазѕ 


сопїасі іа Ож сопќасі а бе јор іа 0 
+ &Э- = 
ГЕ 
заїагу Тон 
Бату пі 


ауаіабіе 
уеагѕ_ехр 


аеѕсгіріоп 


сопїасї его 


сопіасї_іа 
0+х 
сопќасі іа О іп(егеѕі_ іа нур 
85: пате 
а 
о 


іпќегеѕі_ 19 Ож 


ргої іа Ож 


#гѕї пате 
ргоѓеѕѕіоп – 


рһопе 


етаі! 
депаег 
2029; +х `В 
рго#_ 4 24 ѕеекіпо_іа «у 
Ѕїаќиѕ 19 «д 


21р_ сое Ож 
сќу 
Зае 


5їаїиѕ ја О 
Ѕїаїиѕ 
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упражнение. решение 


д Напишите запросы для получения ответов на следующие вопросы (используйте 
Аражнение соединения и некоррелированные подзапросы там, где это уместно). Используйте 


| д "омение схему базы данных дхесѕ 115+. 


Выведите все должности с зарплатой, равной наибольшей зарплате из таблицы јор 1іѕёіпдзѕ. 


| Резульилаилы Внешнего запроса сравни- 
ваюился со значением МАХ(ѕа(ағу). 


| < Подзапрос возвращаеил 
ЅЕГЕСТ Ее ЕКОМ об_5#и4$ 900 значение. 


М/НЕВЕ заагу = (ЅЕГЕСТ МАХ(ѕаЇаку) 


| ЕОМ јор |(ѕъіма5); { 
МАХ возвращаеил наиболь_ 
| МОЮ зарилаилу 8 илаблице. 


| Выведите имена и фамилии людей с зарплатой выше средней. 


| Внешний запрос получаеил резульилаил подза- 
проса и возвращаеил записи, у комлорых «ва[агу» 
| больше вычисленного среднего значения. 


| ЅЕГЕСТ илс.НуЕ_паиле, илс. (аѕё маиле 
РЕКОМ илу_соитас$ илс 
| МАТОКАЕ ЈОІМ јоб сигем јс 


(7 Манев јс,заіаку > (ЅЕГЕСТ МЯСУ) ЕВОМ јо синек) 

Есилесилвенное соеди - 

| нение Возвращаеил | 
информацию о людях 

| 9 коиорых зарилаила н 
иревышаеил значение, среднюю зарилаилу., 

| бозвраицаемое вну – 
илренним запросом. 


2 
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подзапросы 


Найдите всех веб-дизайнеров, у которых почтовый индекс (2ір сойе) совпадает с почтовым индексом | 
какой-либо вакансии веб-дизайнера из таблицы )оь_11$%1п93. 


Для получения полезной информации о найден - | 
ных людях (имя, фамилия, илелефон) необходимо | 
РД вбоспользоваилься есилесилвенным соединением. 


| ЅЕГЕСТ илс.ЁїкѕЕ мамле, илс.|а$6_паиле, илс. рлоле ЕКОМ илу сомасЕѕ илс 
У МАТОКАЕ ЛОМ јоб сигем јс М/НЕВЕ јс е = “мер деѕідмег' АМ” илс.2ір_соде | 
[М (ЗЕТЕСТ р ЕКОМ јоб (їла УМНЕВЕ НЫЕ = "мер 4еядиег); | 


р 


Так как ио 

я ии можеил вернуиль. более одного Вниилренний запрос же 

ты рассмаилриваем результлаилы как ерл все почиловые индексы 
ор, для проверки иринадле И 


жносили к коилоро- д веб-д зайнеров. 
ГД и 
МЧ используется ключевое слово <<!» вакансий 8 | 


Выведите список всех людей, у которых почтовый индекс (ір соае) совпадает с почтовым индексом | 
человека, получающего максимальную зарплату. 


Вопрос с иодвохом — 6 илаблице можеил быть сразу несколько чело- 
Век с максимальной зарилаилой. Эило означаеил, чило В запросе при - 
деился использоваиль ІМ и нам понадобяился два иодзаироса. 

29а 


Внешний запрос получаеил почиловые индексы | 
и ищеил совладения 8 илаблице илу_соиасіѕ. Так Средний Ц. 
как средний подзапрос можем вернуиль долее лочиловые не Находиџл | 
одного почилового индекса, мы используем 1М№. б максимальной АА 
илаилой 
д | 


ЅЕГЕСТ [4$_паиле, Низ плате ЕКОМ илу_соиЁасё5 РА | 

М/НЕКЕ гір содйе ІМ (ЅЕГЕСТ илс2ір сойе ЕКОМ Е илс 

МАТУКАЕ ЛОМ јоб_сиггемё јс | 

\М/НЕКЕ јс.ѕа[аку = (ЅЕГЕСТ МАХ(ѕаіағц) ЕКОМ јоб сиғгел?)); | 
Подзаирос с наибольшим уровнем вложенносили | 
получаеил максимальную зарилату из илаблицы 


Јор сиғүєи+. Так как резульилаил предсилавляеил собой | 
скалярное значение, мы можем использоваиль =. 


АЕ, И, ЕЕ о В сое СЕ = 25 ый 
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коррелированные п20:апросы 


Коррелированные подзапросы 


Если некоррелированные подзапросы 
существуют сами по себе, могу поспорить, 
что коррелированные подзапросы каким-то 
образом зависят от внешнего запроса. 


гт | Е 8—7 


| | Правильно. В модели с некоррелированным 
подзапросом внутренний запрос (то есть 


при условии выполнения внешнего. 


"ге 
| подзапрос) интерпретируется РСУБД после 
| внешнего запроса. 
Таким образом, в модели с коррелированным подзапро- 
! сом выполнение внутреннего запроса ВОЗМОЖНО ТОЛЬКО 


438 


Следующий запрос подсчитывает количество увлечений 

в таблице іпіегезі для каждого человека в ту сопіасізѕ, 
а затем возвращает имена и фамилии людей с тремя увле- 
чениями. 


ЗЕГЕСТ тс.Ғігѕ пате, тс.1аѕє пате 
ЕВОМ ту сопёасіѕ А5 тс 


м: Псевдоним для ил 
Ч-со/лЕас+ 
ИНЕВЕ создаеился во Вненем запросе. 


3 = ( 
ЗЕЬЕСТ СООМТ (*) ЕВОМ сопёасё іпіегеѕі 


зз ра 5 пс-сорзвесыс Чилобы значение илс.солЁасі_ 
А могло ислользоваилеся 


В иодзаиросе использцеился во Внцилреннем запросе, 
ка сначала должен быль 906! 
лолнен Внешний запрос. 


Подзапрос зависит от внешнего запроса. Обработка внутреннего 
запроса станет возможной только после того, как внешний запрос 
предоставит значение сопфасе 1а. 


В подзапросе используется псевдоним таблицы ту сопёасїзѕ — тс, 
который был создан во внешнем запросе. 


„лава 9 


подзапросы 


Коррелированный подзапрос е МОТ ЕХ1$Т$ 


Очень распространенный сценарий использования коррелированного 
подзапроса — поиск во внешнем запросе всех записей, у которых нет 
соответствующих записей в связанной таблице. 


Допустим, Грег хочет расширить круг клиентов своей службы поиска 

работы. Для этого он собирается разослать сообщения всем людям 

изму сопеасез, данные которых еще не содержатся в таблице 

јор соггепё. Для поиска записей он использует условие МОТ ЕХТЗТ$. 
ЗЕШЕСТ тс.Ғігзі пате Е1гзЕпаше, юс.1аѕі паше 1азёпате, шс.ета1] ета11 
ЕВОМ шу сопёас+з тюс Запрос с МОТ ЕХІЅТЅ на 

6 иладлице | 8 
: и 

(ЗЕТЕСТ * ЕВОМ јор сиггеп+ јс це јоб сигуеи. 


МНЕВЕ тс.сопёасё іа = јс.сопёасё іа ); 


+ 
+кто и Орель 


Соедините каждую часть приведенного выше запроса с описанием того, что она делает. 


тс.Ғігѕі пате Ғігѕіпате Назначает псевдоним для поля тс.1аѕї пате 


МНЕВЕ МОТ ЕХТ$Т$ 
Если два значения сопіасё іа совпадают, 


МНЕВЕ тс.сопёасі іа = условие выполнено 


јс.сопёасі іа Назначает полю псевдоним Ёігзіпате 


ЕКОМ ту сопіасіѕ тс 
Выбирает все поля таблицы с псевдонимом јс 
тс.Іаѕї пате 1аѕёпате 


Назначает полю псевдоним етаі1 
ЅЕ1ЕСТ * ЕКОМ 


05 соггепі јс Истинно, если записи не найдены 


пс.емаі1 етаі1 Назначает псевдоним для таблицы ту сопіасёзѕ 
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подзапросы и ЕХ!5Т5/МОТ ЕХІЅТЅ 


ЕХІЅТ8 и МОТ ЕХІЅТЅ 


По аналогии с ТМи МОТ ІМ, в подзапросах также можно ис- 
пользовать ключевые слова ЕХІЅТЗ и МОТ ЕХТ5Т5. Приведен- 
ный ниже подзапрос возвращает данные из ту сопіасіз, 

у которых значение сопќасї 14 по крайней мере один раз 
встречается в таблице сопёасі іпёегезі. 


ЅЕТЕСТ шс.Е1гзЕ пате Ғігѕзіпапе, шс.1азе пате Іазіпате, шс.ета11 ета11 


Заирос с ЕХІЅТЅ находил имена, фамилии и адреса элекилрон- 
ной почилы людей из илаблииы илч_соифасй$, у коилорых значение 


дей соифасЕ {Я по крайней мере один раз всилречаетлся 8 илаблиие 
соифась пифегезт. 


(ЗЕЦЕСТ * ЕВОМ сопіасі іпіегеѕё сі ИНЕВЕ мс.сопфасе іа = с1.сопфас® іа ); 


ЕВОМ ту сопіасєз шс 


МНЕВЕ ЕХІЅТЅ 


+ 
*кте и Ко АЗИ 


Соедините каждую часть приведенного выше запроса с описанием того, что она делает. 


тс.Ғігѕ пате Ёігѕёпате Назначает псевдоним для поля пс.1аз® паме 


ИНЕВЕ МОТ ЕХТЗТ5 р 
Если два значения сопёасі іа совпадают, 


ИНЕВЕ тс.сопбасі іа = о 


9с.сопбас®_1а Назначает полю псевдоним #ігѕёпате 


РКОМ ту сопёасїѕ тс 
Выбирает все поля таблицы с псевдонимом јс 


пс.Іаѕї пате 1аѕёпате 

Назначает полю псевдоним етаі1 
ЅЕІЕСТ * ЕКОМ 
јор соиггепї јс Истинно, если записи не найдены 


пс .ета11 етаі1 Назначает псевдоним для таблицы пу сопёасіѕ 
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подзапросы 


Возьми в руку карандаш 


Напишите запрос для получения адресов электронной почты 
6.9 людей, которые имеют не менее одного увлечения, но при этом 
отсутствуют в таблице уор сиггепі. 


" (звела на с, 444. 
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успех подзапросов! 


Служба поисКа работы Грега принимает заказы 


Грег вполне освоился с выборкой данных с исполь- 


зованием подзапросов. Он даже научился пользо- 
ваться ими в командах ТМЗЕВТ, ОР”РАТЕ и РЕЪЕТЕ. 


Он снял небольшой офис и собирается провести ве- 
черинку, чтобы отпраздновать начало нового дела. 


Часто 


адаВаеМые 


Интересно, удастся ли 
мне найти своего перво- 
го работника в таблице 
јоБ_аесігеа... 
зна. 


`` 


Вопсы 


|: Итак, подзапрос можно вложить в другой подзапрос? 


. >. 

(} Безусловно. Количество уровней вложения подзапросов 
ограничено, но в большинстве РСУБД оно значительно превы- 
шает практический «потолок». 


|: Как лучше всего строить подзапрос внутри подзапроса? 


() Попробуйте написать маленькие запросы для различных 
частей вопроса. Присмотритесь к ним и попробуйте скомбиниро- 
вать. Если вы пытаетесь найти людей с такой же зарплатой, как 
у самого высокооплачиваемого веб-дизайнера, разбиение запро- 
са может выглядеть так: 


Найти самого высокооплачиваемого веб-дизайнера 
Найти людей, зарабатывающих х 


после чего подставить первый ответ на место х. 
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. 
|: Подзапросы мне не нравятся, могу ли я использовать 
вместо них соединения? 


. 
() В большинстве случаев — да, можете, но сначала необходи- 
мо еще кое-что узнать о соединениях... 


подзапросы 


По дороге на ВечеринКУ 


р ру ым заг ОЛОВКОМ. 
І ег обна живает В газете статью) С сенсациоин м 


ІМОГЕВҮЕН .. 


РАЕВА 
ОЛАР СУ! 


СКРЫТЫЕ СОЕДИНЕНИЯ 


Соседи утверждают, что подзапросы - «не что иное», как 
обычные соединения, и «...люди должны узнать правду». 


Трой Армстронг 
Репортер ПМОЧЕВУЕВ 


Дейтавиль — Источники Іпаџегуег подтвердили то, что что 
в течение многих лет считалось обычными слухами. Соеди- 
нения и подзапросы могут использоваться для реализации 
абсолютно одинаковых запросов. К смущению местных жи- 
телей, все, что можно сделать с помощью подзапроса, также 
можно сделать с помощью некоторого типа соединения. 


Габ 
? 
у ч 
ГА 

«Это ужасно, — рыдает учительница Хейди Мусгроув, — Как А 
я скажу детям, что после всех трудов по изучению подзапро- 14 РҮ = 
сов, после всего потраченного на них времени они могли 

просто использовать соединения? Это катастрофа!» Местная жительница Хейлли 


Мусгроув узнает шокирующую 


Тема будет продолжена в следующей главе, где внешние правду о подзапросах. 


запросы станут предметом пристального внимания обще- 
ственности. 


ВЫХОДИТ, МЫ ТОЛЬКО зря ПОТРАТИЛИ ВРЕМЯ? И ПОДЗАПРОСЫ 


НИЧЕМ НЕ ОТЛИЧАЮТСЯ ОТ СОЕДИНЕНИЙ? 


ОТВЕТ НА ЭТОТ ВОПРОС ВЫ УЗНАЕТЕ В СЛЕДУЮЩЕЙ ГЛАВЕ. 
злее $ 443 


краткий обзор 54! 


Новые инструменты 


В главе 9 вы овладели искусством 
построения подзапросов. Вспомните 
то, что вы узнали в ней. Полный список 
инструментов приведен в приложении ІІ. 


Внешний запрос 
Запрос, содержащий 

внумренний запрос (мод- 
запрос). 


Внутренний запрос 
Запрос 


ГЛАВА 9 


Некоррелированный 
подзапрос 
Подзаирос, коплорый су- 
идесилвцеил сам мо себе 

и не содержиил ссылок на 
данные внешнего запроса. 


Запрос, вложенный 
6 другой запрос: Так ч 
же МОЖЕМ называть 

нним заиросом”- 


Возьми в руку карандаш 


^ 
Решени? Напишите запрос для получения адресов электронной почты 


қ. Сос. 441 людей, которые имеют не менее одного увлечения, но при этом 
, | отсутствуют в таблице } оБ_сиггепе. 


ЅЕГЕСТ илс.еилаЙ ЕКОМ илу_соифасё$ ис М/НЕКЕ 
ЕХІЅТ5 


(ЅЕЕСТ * ЕВОМ солмас ГиЁегеѕЕ сг НЕВЕ илс.соифас®_[Р = сгсоифасЕ 1р) 
АМР = Как обычно ири реализации д 


вух условий 
должны быиль 9х у ии, коилорые 
МОТ ЕХІЅТЅ ОВО р исилинны одновременно, 


| ЕКЕ используется связка АМР. 
(ЅЕІЕСТ * ЕКОМ јоб сигет јс 


ММНЕВЕ илс.сомёас 1а = ]с.соифасе (А ); 
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Ж 
‚ Новые приемы * 


А после внутреннего соединения — 
левое внешнее с «восьмеркой»... 
На этот раз судьи непременно 
поставят мне высший балл... 


Пока вы знаете только половину того, что необходимо знать 
осоединениях. Вы видели перекрестные соединения, которые возвращают 
все возможные комбинации записей, и внутренние соединения, которые воз- 
вращают записи обеих таблиц при наличии совпадения. Однако существуют еще 
и внешние соединения, которые возвращают записи, не имеющие совпаде- 
ний в другой таблице, самосоединения, которые (как ни странно) соединяют 
таблицу саму с собой, и союзы, которые объединяют результаты запросов. 
Освоив эти приемы, вы сможете получить все данные точно в том виде, в кото- 
ром они вам нужны. (И узнаете правду о подзапросах, как мы и обещали!) 


внешние соединения 


Уничтожение старых данных 
а обр 


Надо бы почистить таблицу ргоѓеѕѕіопѕ. Там хра- 
нятся некоторые значения, которые я больше не ис- 
пользую. Как легко найти профессии, не связанные 
ни с одной записью в таблице ту_сопїасїѕ? Вну- 
треннее соединение для этого не подойдет. 


Для получения этой информации можно 
воспользоваться внешним соединением. 


Давайте сначала посмотрим, как работает внешнее соединение, 
а потом мы выясним, как же найти неиспользуемые профессии. 


Внешние соединения возвращают все записи одной из таблиц 
вместе со всеми соответствующими данными из другой таблицы. 


При внутреннем соединении сравниваются записи двух таблиц, 
причем порядок следования этих двух таблиц неважен. 


Давайте в общих чертах посмотрим, что делает эквивалентное 
соединение. Мы получаем столбцы, связанные совпадением зна- 
чений соу іа в обеих таблицах: 


ЗЕГЕСТ 9.91.1, +.боу 
ЕВОМ 91г1$ д 

ТММЕВ ЈОІМ ұоуѕ Е 

ОМ 9.Еоу іа = ®.Еоу іа; 


Эквиваленилное 
соеди 
нение срав- У ёоуѕ 
Ниваеил записи 
эмлих двух рда - ШР ЕИ 


губная гармошка 


бейсбольные 
карточки 
кубики 


7 волшебный 
экран 


Наили 
резульмлаило!. 


—> 


внешние соединения, самосоединения и союзы 


Левое, правое... 


С другой стороны, внешние соединения в большей степе- 


ни зависят от отношений между двумя таблицами, чем все В левом внешнем соеди- 
рассмотренные ранее типы соединений. нении для КАЖДОЙ 


Левое внешнее соединение (ІЕЕТ ООТЕВ ЈОІМ) перебира- 


ет все записи левой таблицы и ищет для каждой соответ- З НАПИСИ ЛЕВОЙ таб ЛИ- 


ствие среди записей правой таблицы. В частности это 


удобно, когда между левой и правой таблицей существует ЦЫ ищетея соответетвие 


связь типа «один-ко-многим». 
© є 
Чтобы понять логику внешнего соединения, необ- ереди запиееи правои 


ходимо понять, какая таблица находится «слева», 


аа Ча: таблицы. 


В левом внешнем соединении таблица, следую- 
щая после ЕКОМ, но ДО ЈОІМ, считается «левой», 
а таблица, следующая ПОСЛЕ ЈОІМ, считается 
«правой». 


Таблица перед ключевыми сло - 
вами левого Внешнего соедине- 
ния счиилаеился «левой». 


Левая иладлица 


= 


Левое Внешнее 
единение. 
ыы Правая 
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левое внешнее соединение 


Пример левого Внешнего соединения 


При помощи левого внешнего соединения мы можем узнать, 
какая игрушка принадлежит той или иной девочке. 


Ниже приведен синтаксис левого внешнего соединения на при- 
мере уже использовавшихся таблиц. Таблица діг15 указана пер- 
вой после ЕВОМ, поэтому она считается левой таблицей; далее 
следуют ключевые слова ІЕЕТ ООТЕВ ЈОІҸ и наконец, таблица 
фоуз считается правой таблицей. 


Иилак, левое Внешнее соединение иеребираеил все 
____ залиси левой иладлииы (ч1и[5) и ишем для каждой со- 
оилвеилсилвие среди записей правой иладлицы (045). 


ЗЕБЕСТ 9.9411, +. оу 
ЕРОМ 41:15 д =” `Чаблица 31615 предмлесилвцеил ГЕРТ ООТЕК 


ЈОІМ, поэилому она ябляеился левой... 
БЕРЕТ ООТЕВ ЈОІМ Фоуз + аль 
1 Ца #045, след 
ОМ 9.Еоу ій = Є.боу ій; СЕТ О0тек Јолу 22580:499. за 


‚Я 
правой... Вляеился 


Таблица дб предилесилвуеил 
ГЕРТ ООТЕВ ЈОІМ, поэилому а иладлица 1995 


она являеился левой... следующая за 1 Ерт 
ОЧТЕК ЛОМ, явля ~ 
А еился правой. 
91.13 соуз 


И еамоле"____ 
солдатики 


7 солдатики | 
карточки 
| 


волшебный экран 
пружина 


8) 


эа 


Результат левого Внешнего совдинания 


аи: 


5 
6 
7 
8 


/ 


Результат тот же, что и при внутреннем 
соединении. 


Резулеилаи^ 
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И все? Спрашивается, чего 
мы добились? Выходит, внешнее 
соединение ничем не отличается 
от внутреннего. 


Отличается: внешнее соединение возвращает запись 
независимо от того, есть у нее совпадение в другой 
таблице или нет. 


Отсутствие совпадений обозначается значением МОТГ. В нашем 
примере с девочками и игрушками МОТТ, в результатах означает, 
что данная игрушка не принадлежит никому из девочек. Очень 
ценная информация! 


Значение МОТЛ, в результатах левого 
внешнего соединения означает, что 
правая таблица не еодержит значений, 
еоответетвующих левой таблице. 


« Возьми в руку карандаш 


Напишите, как, по вашему мнению, будет выглядеть таблица резуль- 
татов этого запроса. 


ЅЕ1ЕСТ 9.91г1, ®.®оу 
ЕВОМ Коуз Е 

ТЕЕТ ООТЕВ ЈОІМ 91:13 д 
ОМ 9.Еоу_1а = &.+оу 1а; 


(Подсказка. Таблица резульилаилов 
будеил содержаиль 8 записей.) 
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возьми в руку карандаш. решение 


«. ВОЗЬМИ в руку карандаш 
< Решение 
4 В этом запросе таблицы поменялись местами. Напишите, как, 
по вашему мнению, будет выглядеть таблица результатов. 


ЅЕІЕСТ 9.91:1, +.ёоу 
ЕВОМ +оуз & <— Левая илаблица 
ТЕЕТ ООТЕВ ЈОІМ 91:13 д — 
7 ОМ д.ёоу ій = Є.+оу ій; правая улаблица 


На эилоил раз каждая запись 6 илаблиие 045 
(левая илаблииа) проверяется по илаблице 45 


(правая илаблииа). $ 


Левая илаблица Правая илаблииа 


БЯ 91:18 


обруч 
самолет 
солдатики 


губная гармошка 


бейсбольные 
карточки 


С изменением порядка илаблии 
изменяеился ц Резульилаил. 


БОА совпадение дидеил 

найдено, резульилаил = к 

Вклкочаеился 6 иладлицц. Силолбиы 6 илаблице 

Если совпадение оил – Салли Резульилаилов ио - 

суилсилёцеил, запись мош бейсбольные Казаны 6 порядке их 
бон карточки ВЫБОРКИ. Эџлоџд 


6 иладлиие Все 
це се равно порядок не име- 


создаеился, но оилсцил- 
силвующее Қ ЛЕВОН общего а 
пружина ЛЕВОИ ц ПРАВОЙ 


заменяеилея МОЦ. 
иладлицей соединения 
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Ниже приведены два результата. Напишите для каждого из них левый внешний 


х запрос, который мог бы привести к его анию, а также таблицы адіг1ѕ и є 
пражнение А р созд ао 
с данными, соответствующими результатам. 


Запрос Результат левого внешнего соединения 


МИ 


Эило мы сде- 
Левая таблица Е за вас. Правая таблица 


Эила задача 
посложнее. 


Запрос Результат левого внешнего соединения б 


водяной пистолет 


Сео 
моц. 


ѕаПу 


Левая таблица Правая таблица 


дальше » 451 


упражнение. решение 


Ниже приведены два результата. Напишите для каждого из них левый внешний 
запрос, который мог бы привести кего созданию, а также таблицы 91г1$ и ёоуѕ 
с данными, соответствующими результатам. 


Результат левого внешнего соединения 
Запрос 


ЅЕГЕСТ 4.411, %0ч 
ЕКОМ 46 д 

ГЕЕТ ООТЕК ЈОІМ 6045$ 
ОМ д.04 14 = ЕЛоЧ 1а; 


Игрушки, ири 
сцилсилвующие 


Левая таблица Правая таблица 
ь " 0 6 резульилаилах. 


604$ 


водяной ии ~ 


силолеил 


2 


Здесь можеил быль любое значение Побилоряющиеся значения указы - 
ѓоу 14, не сущесилвующее в илабли - вакоил на ило, чило одна игрушке 
це Ё0уѕ, полому чило 6 силолбие оц есиль у нескольких девочек. 
резульилаила храниился МОШ. 

Запрос Результат левого внешнего соединения 


ЅЕГЕСТ 4.41, #049 
РЕКОМ 6045 Е МОСЦІ означаеил, 
ГЕЕТ ООТЕК ЈОІМ дік д чило ни Ч одной 


ея |. из девочек неил 
ОМ д.04_іа = оц (а; дудки. 


И. | лере 72 
о Даа 


Левая таблица Правая таблица 


045 


оц 
Водяной ии ~ 
силолеил 


1 


дчдка 


ирижина 


452 глава 10 


внешние соединения, самосоединения и союзы 


Внешние соединения и множественные совпадения 


Как видно из этого примера, запись в результирующем ЗЕЬЕСТ 9.91.1, і.Їіоу 
наборе создается даже при отсутствии совпадений в ЕКОМ 6оуз і 

другой таблице, а при множественных совпадениях бу- ТЕЕТ ООТЕК ЈОІМ 9111$ 3 
дет создано несколько записей. Вот что происходит при ОМ с.соу іа = ї.іоу іа; 


левом внешнем соединении: 


+оүз 91:13 


[Г ' [| водяной пистолет — 


пружина 


Запись с водяным пистолетом (+оу$) сравнивается с записью Джен (91:15): іоуѕ.іоу іа = 1, 
аіг1ѕ.їоу іа = 1 

Есть совпадение. 

Запись с водяным пистолетом (ёоуз) сравнивается с записью Клео (31х13): іоуѕ.іоу іа = 1, 


діг1ѕ.ёоу іа = 1 

Есть совпадение. № 
Запись с водяным пистолетом (соуѕ) сравнивается с записью Салли (9іг1з): соуѕ.іоу іа = 1 
діг1ѕ.іоу іа = 3 

Нет совпадения. 

Запись с водяным пистолетом (соуз) сравнивается с записью Марты (9іг15): соуѕ.їіоу іа = 1, 
діг1ѕ.іоу іа = 3 

Нет совпадения. 

Запись с дудкой (ёоуз) сравнивается с записью Джен (91х15): ёоуѕ.оу іа = 2, 
діг1ѕ.боу іа = 1 

Нет совпадения. 

Запись с дудкой (ёоуѕ) сравнивается с записью Клео (41.15): соуѕ.їоу іа = 2, 

9іг1ѕ.іоу іа = 1 

Нет совпадения. 

Запись с дудкой (соуз) сравнивается с записью Салли (9іг15): їоуѕ.ёоу іа = 2, 
9іг1ѕ.іоу іа = 3 

Нет совпадения. 

Запись с дудкой (Еоу5) сравнивается с записью Марты (91:15): ёоуѕ.їоу іа = 2, пистолет 
діг1ѕ.іоу іа = 3 


> Клео водяной 
Нет совпадения. пистолет 


Конец таблицы, создается запись с МО. е а 


ВОДЯНОЙ 


Джен 


Запись с пружиной (соуз) сравнивается с записью Джен (31х13): іоуѕ.ёоу іа = 3, 

діг1ѕ.іоу іа = 1 
Нет совпадения. пружина 
Запись с пружиной (соуѕ) сравнивается с записью Клео (91:15): іоуэ.соу іа = 3 
діг1ѕ.ёоу іа = 1 

Нет совпадения. 

Запись с пружиной (+оуз) сравнивается с записью Салли (діг15): іоуѕ.ёоу іа = 3, 
діг15.ёоу іа = 3 

Есть совпадение. / 
Запись с пружиной (соуѕ) сравнивается с записью Марты (діг15): ёоуѕ.ёоу іа = 3, діг1ѕ.соу іа = 3 
Есть совпадение. 


дальше » 453 


правое внешнее соединение 


Правое Внешнее соединение 


Правое внешнее соединение почти полно- 
стью аналогично левому внешнему соеди- 
нению, кроме того, что оно сравнивает 
правую таблицу с левой. Следующие два 
запроса возвращают абсолютно одинако- 
вые результаты. 


ЅЕ1ЕСТ 9.91.1, ®.Воу 
ЕВОМ +оуз + «— Правая илаб 


лица. 


ОМ д.+оу іа = +.+оу іа; 


и 


В обоих запросах 


Левая илаблица. 


ВТСНТ ОЧТЕВ ЈОІМ діг1ѕ д <-/ 


Правое внешнее соединение 
ищет в левой таблице еоответ- 
етвия для правой таблицы. 


ЗЕТЪЕСТ 9.а1г1, &. оу 
ЕВОМ 91:15 9 < Левая ипладлииа. 


ТЕРТ ООТЕВ ЈОІМ +оуүѕ + <— 


Правая 


ОМ д.ёоу іа = +. + іа; о 
9 У_ оу 1 илаблица: 


А №, Эилоил запрос уже 


приводился на с. 448. 


илаблица 41 явля - 


Левая илаблииа 


(6 обоих запросах). в. 


вился левой иладлиией. 


_ Правая иладлица 
4 (6 обоих запросах). 


Наши — 


резцлеглаил" 
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Джейн солдатики 
Салли губная гармошка 


, 
* Есть ли причины для использования ле- 
вого внешнего соединения вместо правого? 


(} Заменить ключевое слово 1ЕЕТ ключевым 
словом ВТСНТ проще, чем изменять порядок 
таблиц в запросе. Достаточно изменить всего 
одно слово — вам не придется переставлять 
имена таблиц и их псевдонимы. 


С другой стороны, на практике обычно бывает 
проще всегда придерживаться одного типа 
(скажем, левых внешних соединений) и менять 
местами таблицы. В этом случае код получает- 
ся более понятным. 


Правое У 
Внешнее 
Левая соединение. 


Частпо 
Задаваемые 


Вопњсы 


внешние соединения, самосоединения и союзы 


Правая 
иладлица. 


* Если существуют ЛЕВОЕ и ПРАВОЕ 
внешние соединения, то существует ли со- 
единение, возвращающее результаты левого 
и правого соединений? 


() В некоторых (но не во всех) РСУБД 
существуют такие соединения, называемые 
ПОЛНЫМИ внешними соединениями. Они не 
поддерживаются в МуЗСЕ, 501 Зегуег и Ассеѕѕ. 


дальше › 455 


соединение таблицы с собой 


Нельзя ли воспользоваться внешним 
соединением для того, чтобы связать 
таблицу с ней самой? Иногда это мо- 
жет быть полезно. 


Одна и та же таблица может 
использоваться в качестве левой 

и правой таблицы соединения. 

И хотя сама идея такого соединения на пер- 
вый взгляд может показаться странной, она 
может оказаться полезной. Рассмотрим при- 
мер ситуации, в которой может пригодиться 
внешнее соединение таблицы с ней самой. 


Но сначала необходимо разобраться с одной 
проблемой, которая возникла в Дейтавиле... 
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Пока мы занималиеь Внешними соединениями... 


В Дейтавиле клоуны организовали проф- 
союз, и у них появились свои начальники 
и подчиненные. Ситуация принимает 
угрожающий оборот, и мы должны сле- 


дить за тем, кто является начальником Мистер Снифлз 
и кому из начальников подчиняется тот 
или иной клоун. 
Кларабелл Снаглз 
Перед вами пример новой иерархии 
клоунов. У каждого клоуна имеется один 
начальник (кроме самого главного клоу- 
на, Мистера Снифлза). ЫЯ 
Зиппо Элси 
Бэйб Пиклз Скутер Мистер 
Бонзо 
Хобо 


Перед вами текущая схема базы данных. 
Давайте подумаем, как лучше внедрить 
в нее новую информацию. 


_ҸевегірНоп | 


асіміїу іа Оу 


а «= 


Іосайоп 14 


іосаїоп іа 
о— 


Іосаїоп 


0 мозговой 
соран 


Как изменить структуру схемы, 
чтобы сохранить в базе дан- 

ных информацию об иерархии 
клоунов? 


Вам смешно, наде- 
юсь? Ведь я же клоун... 
Смешно, спрашиваю? 


Снифлз, начальник 
и Снаглз. 
К.ларабелл у 
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добавление таблицы сіомп Боѕѕ 


Создание новой таблицы 


Мы можем создать таблицу с перечислением всех 
клоунов и идентификаторов их начальников. Вот 
как выглядит иерархия с идентификаторами. 


10 Мистер Снифлз 


5 Кларабелл 3 Снаглз 


% к м 


Ө 2Пиклз р ню м Хоб 
истер Хобо 
9 Бонзо Скутер Р 


8 Бэйб 


В новой таблице для каждого клоуна указан иденти- 
фикатор его начальника из таблицы с1омп іпїо. 


«один-к-одному». 


силолдие. 
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Между таблицей с1оип розз и табли- 
цей с1омп_1пЕо существует связь типа 


У Мистера Снифлза неил начальни- 
ка, но иденилификаилор ему нужен. 

В силолбце «воз. 14» дудеил указан его 
собсилвенный иденилификаилор, чило- 
ды избежать значения МОЦ. В эилом 


внешние соединения, самосоединения и союзы 


Место новой таблицы В схеме 


Посмотрите на текущую схему базы данных. Как лучше 
встроить в нее новую таблицу? 


ме 


асіімїу іа Оу 


Іосайоп 19 
ок 


Ситуация немного странная. В схеме возникает связь 
типа «один-к-одному» с іа (первичный ключ) и связь 
типа «один-ко-многим» с роѕѕ іа. И первичный ключ, 
и внешний ключ находятся в таблице с1омтп іпёо. 


Похоже, мы можем воспользоваться таблицей 
со связью «один-к-одному». Но раз таблица 
не содержит закрытой информации, нельзя ли 
встроить эти данные в основную таблицу? 


о мозговой 
О УШТУРМ 


Можно ли хранить информацию об иерархии 
клоунов без создания отдельной таблицы? 
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рефлексивный внешний ключ 


РефлексиВный Внешний Ключ 


В таблицу с1омп_1пЕо следует добавить новый столбец 

с информацией о том, кто является начальником того или 
иного клоуна. В новом столбце будет храниться идентифи- 
катор начальника. Мы назовем его розз іа, как в таблице 
сІомп роѕз. 


В таблице с1оип роѕэ столбец розѕ іа был внешним 
ключом. При добавлении в с1омп іпЁо этот столбец все 
равно остается внешним ключом, хотя и находится в другой 


таблице. Такие внешние ключи, ссылающиеся на другое поле 


той же таблицы, называются рефлексивными. 


Мы считаем, что Мистер Снифлз является своим собствен- 
ным начальником, поэтому у него значение роѕз іа совпа- 
дает с іа. 


Рефлексивным внешним ключом называется первичный 
ключ таблицы, используемый в той же таблице для другой цели. 


Новый силолбец «‹роѕс ід», 
коилорый мы иросило 
добавили в иладлицу 
соли. В силолдце 


храниился рефлексивный 
внешний ключ. 


с1омп_11пЕо 


7 
0 
УМ 


РЕФЛЕКСИВНЫЙ внеш- 
ний ключ — первичный 
ключ таблицы, иеполь- 
зуемый в той же таблице 


для других целей. 


——___ По ссылке на поле «ід» 
6 илой же иладлице 
можно определииль, 
Кило из клоунов яв- 


ляется начальником 
Элси. 


И снова 6 силолдие < о55 12» 
Мистера Снифлза храниил- 


М ся его собсилвенный иден- 


илификаилор. 
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Соединение таблицы с ней самой 


Допустим, мы хотим вывести список всех клоунов и их начальни- 
ков. Список всех клоунов с идентификаторами начальников легко 
выводится запросом ЅЕІЕСТ: 


ЗЕЪЕСТ пате, роѕѕ іа РВОМ с1очп_1пЕо; | №083 | 


Снаглз 
Но нам нужны пары имен клоуна и его начальника. ее 


Возьми в руку карандаш 


Имеются две идентичные таблицы, с1омп _1пЕ01 и с1омп іпёо2. 
Напишите соединение для получения таблицы результатов с имена- 
ми каждого клоуна и его начальника. 


с1омп іпёо1 с1омп_1пЕ02 
ЕЙ 8 Е Е 9% 


[м | 

[2 |  Пиюз | 
|2435] Мистер Хобо 
Ега 


[ возм 
ВЕ 
5 
МЕН 
5 


Е 
| 4 | Мистер Хобо__ Е 
ВЕН ЕСТ: = В 
88 = а. ЛБЭЙО29] 
ЕС ВЕНЕ: 


1 
2 
рб | Сю | 
[8 | 5 
92 > бб 21 
[ 10 | Мистер Снифлз | 


10 
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возьми в руку карандаш. решение 


«„ Возьми в руку карандаш 
№ < Решение Имеются две идентичные таблицы, с1омп_1п01 и с1оип іпёо2. 
сч Напишите соединение для получения таблицы результатов с имена- 
ми каждого клоуна и его начальника. 


с1омп_1пЕо1 с1омт іп#о2 


Элси 


Снаглз 


х 
Чилобы не заицилаилеся ны 
силолдиах С именами < Аар 
ы назначаем вилоромУ исе 


СЕЁЕСТ с1.латле, с2.паиле АЅ 0055 КА «055». 
ЕКОМ сіоми ілЁо1. с1. 

ІММЕВ. ЈОІМ сои їлѓо2. с2. 

ОМ с1.б055 4 = с2.14; 


б 


Здесь проверяеился совла - 
дение <‹боѕѕ ГА» из илаблицы 
сои. с «ід» из ила 
блицы соло. 
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Потребуется самосоединение 


В только что выполненном упражнении одна таблица 
использовалась дважды. Но в нормализованной базе 

не может быть двух копий одной таблицы. Вместо этого 
для имитации соединения двух таблиц используется само- 
соединение. 


сІомтп 110 


Пиклз 
Снаглз 


Мистер Хобо 


__Ьеза іа 


Этот запрос очень похож на предыдущее задание, но 
имеет существенное отличие. 


7 


ЗЕГЕСТ с1.паме, с2.паме АЅ БЬоѕѕ 
ЕВОМ с1омп іпЁо с1 

ТММЕВ ЈОІМ с1омп іпёо 2 ^ 
ОМ с1.роѕѕ іа = с2.19а; Таблица сои и использцеился 


Обажды, с синонимами с1 (оилкч- 
да дереился росѕ га) и с2 (оилкуда 
дереился имя начальника). ^ 


0 


Вместо двух идентичных таблиц мы используем 

с1оип іпЁо дважды: сначала с псевдонимом с1, а за- 
тем с псевдонимом с2. Далее столбец роѕѕ іа (изс1) 
связывается с именем начальника (из с2) посредством 


внугреннего соединения. Данные силолдиа одразуюился вни 
м 


АЫ ииренним соединением боѕѕ Го первого 
экзелиляра иладлииы сои (ио (с1) 
и именем начальника, коилорое 


Снаглз дерется из иладлицы соли ілғо (с2). 


Кларабелл 
Мистер Снифлз 
Снаглз 
Мистер Снифлз 
Снаглз 
Снаглз 
Кларабелл 
Кларабелл 
Мистер Снифлз 


Элси 
Пиклз 
Снаглз 
Мистер Хобо 
Кларабелл 

Скутер 
Зиппо 

Бэйб 
Бонзо 

Мистер Снифлз 


При еамоеоединении запросе 

к одной таблице етроитея так, 
как еели бы она была двумя 
таблицами, содержащими 
одинаковую информацию. 
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использование союзов 


Другой способ получения многотабличной информации 


Я пытаюсь построить полный список 
всех должностей, встречающихся в дгедз_ 1151. 
Как узнать, какие должности встречаются 

во всех трех таблицах? 


Три таблицы, о которых говорит Грег. 


Досилуиные 


Раб, 
Ома, комлорую вакансии. 


ая 
а ищуил иреиленденилы. 


радома у (, я 


сотїасї а === 
&5 


јор іа Ож 
«5 


а Ож 


Пока он написал три отдельные команды ЅЕІЕСТ: 


ЗЕГЕСТ +1%1е ЕВОМ јоЬр сиггеп®; 
ЅЕТЕСТ $1%1е ЕВОМ Јјор деѕігеа; 
ЅЕТЕСТ +1%1е ЕВОМ јор 11ѕбіпдѕ; 


Команды работают, но Грег хочет объединить результаты в одном 
запросе и получить список всех должностей, присутствующих 
хотя бы в одной из трех таблиц. 
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Союзы 
Данные Данные 


Существует еще один способ получения ‘ор сиигеит. . А 
АЕС лу 48.09 из јоЬ десіғед, 

объединенных результатов таблиц — так на- 

зываемые союзы (ключевое слово ОМТОМ). 


Кх 

ОМІОМ 
объединяеил 
резчльила- 
мы заиро- 
сов ЅЕГЕСП 


Союз объединяет в одну таблицу резуль- 
таты двух и более запросов на основании 
того, что указано в запросе ЗЕЪЕСТ. Союзы 
можно трактовать как «пересекающиеся» 
значения всех запросов. 


ко всем им 
7 бӧлицам. 
ЅЕІЕСТ +141е ЕВОМ јоЬ сиггерё ОМІОМ \ 
няёи 
ОчІОН АИ анные | 
ЗЕТЕСТ +141е ЕВОМ јо безігеїй —„улих илрех разных из јор (15145: 
Омоч <= запросов 6 одну 
| | е: обшцю пладлииу 
ЅЕГЕСТ &1Е1е ЕВОМ јор 1ізёіпдз; в 
— резцльилаило . 
Бухгалтер 
Небольшая часиь | Адвокат _ |0, 
соилен должносилей 
присуилсилвующих 
Грег замечает, что в результатах нет дубли- в объединенных < 
катов, однако должности перечислены не Резульилаилах из —_ 
по порядку, поэтому он пытается повто- илрех илаблиц. 
рить запрос с добавлением условия ОБОЕВ 
ВУ в каждой команде ЅЕІЕСТ. 
ии 
ЅЕТЕСТ +11е ЕВОМ )оь сиггепЕ ОВОЕВК ВУ +%1%41е 
ОМІОМ ву 
к 
ЅЕГЕСТ +141е ЕВОМ јоЬ 4ез1ге ОБОЕВ ВУ +141е Грег добавил ОКРЕ г 
ОмІоМ Е 6 каждую команду, Чил 


бы должносили 6 илаблиие 
ЗЕТЕСТ +1Е1е ЕВОМ Јор 1ізііпдз ОВОЕВ ВУ +&1%1е; резульнлаилов были циб= 


—— рядочены по алфавии^у. 


со МОЗГОВОЙ 
Штурм 


Как вы думаете, что произошло при выполнении нового 


запроса? 
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правила союзов 


Ограничения союзов 


Запрос Грега не сработал! РСУБД выдала сообщение об ошиб- 


ке, потому что она не знала, как интерпретировать многократ- 
ное повторение ОКПЕК ВУ. 


При использовании ОМТОМ допускается только одно условие 
ОВОЕВК ВУ в конце команды. Это объясняется тем, что союз 
объединяет и группирует результаты нескольких команд 


ЗЕГЕСТ. 


Есть многое на свете, что вам следует знать о союзах. 
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Кодекс союзов В $01 


Количество столбцов 

в командах 5ЕТЕСТ должно 
быть одинаковым. Нельзя 
выбрать два столбца одной 
командой и еще один столбец 
другой. 


Команды $Е1ЕСТ должны со- 
держать одинаковые выраже- 
ния и агрегатные функции. 


Команды 5ЕТЪЕСТ могут сле- 
довать в любом порядке; на 
результаты это не влияет. 


Зи >_:!: 
ви = 6,9 и 


злава 10 


Кодекс союзов 8 501 


По умолчанию 501. исключа- 
ет дубликаты из результатов 
СОЮЗОВ 


Типы данных в столбцах долж- 
ны либо совпадать, либо быть 
совместимыми. 


Если вы по какой-то причине 
ХОТИТЕ получить список со 
всеми дубликатами, исполь» 
зуйте оператор ОЧІОМ А. 
Он возвращает все совпадения, 
не только уникальные. 
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Правила союзов В действии 


Количество столбцов в командах ЅЕІЕСТ должно быть оди- 
наковым. Нельзя выбрать два столбца одной командой и еще 
один столбец другой. 


де ЅЕЕСТ 
ваилься оди- 
во силолбиов. 


ЗЕБЕСТ (ъїєте)ғвом оЬ соггепі 
ОМІОМ 

ЅЕ1ЕСТ ЕВОМ јоЬ аез1геа 
омтом 

ЗЕТЕСТ (тете) ЕВОМ јо 11341198 
ОВРЕВ ВУ +1+1е; 


5 


Если вы хоилииле упорядочить резульилаилы, 
включииле ОРЕК ВУ за последней из объединяе - 
мых команд ЅЕГЕСТ. Эило приведеил к упорядоче - 
нию всего списка резульилаилов. 


В каждой коман 
должно истмолезо 
наковое количесил 


40) 


Резулеллаилеь коилорые нам 
хоилелось бы получии^Р, 


ак. 
р” выглядямл примерно и" 


В этом примере все три столбца относятся к одному 
типу данных УАВСНАБК. В результате столбец, возвра- 
щаемый запросом, тоже относится к типу УАВСНАВ. 


Еее = 
оу-мМоЗГовоЙ 
С Г ШТУРМ 


Как вы думаете, что произойдет, если объ- 


единяемые столбцы относятся к разным 
типам данных? 
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ОМОМ Аі І. 


ЏМІОМ АЦ 


ОМІОМ АІ работает точно так же, как ОМТОМ, если не считать то- 
го, что он возвращает все значения из столбцов — вместо одного 
экземпляра из каждой группы дубликатов. 


ЗЕТЕСТ &11е ЕКОМ јор сиггепі 
омІОМ, АІ. 
На эилоил раз М" < ЗЕБЕСТ &161е ЕВОМ јо деѕігеа 


хоилим получииль все 


значения, хранямие- ОМТОМ АБЬ 


ся 6 силолбиах «Ее» 


всех илрех илаблиц. ЗЕБЕСТ &1%1е ЕВОМ јор 1іѕііпдѕ 
ОВРЕВ ВУ &1+1е; 


<. В этом списке одна долж_ 
носиль можеил вВсилречаилься 


несколько раз. 


До настоящего момента в наших союзах ис- 
пользовались столбцы с совпадающим типом 
данных. Однако в некоторых ситуациях может 
возникнуть необходимость в создании союза 
из разнотипных столбцов. 


Когда мы говорим, что типы данных должны 
быть совместимы друг с другом, это означает, 
что при необходимости их можно привести 

к общему типу; а если этого сделать не удастся, 
выполнение запроса приведет к ошибке. 


Допустим, в союзе тип ТМТЕСЕВ объединяется 
с типом УАКСНАВ. Так как данные УАВСНАВ 
нельзя преобразовать в целое число, в полу- 
ченных результатах тип ІМТЕСЕК будет преоб- 
разован в УАБСНАК. 
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Создание таблицы на основе союза 


Чтобы узнать, какой тип данных будет возвращен в составе союза, необхо- 
димо каким-то образом сохранить эти данные. Команда СВЕАТЕ ТАВІЕ АЅ 
позволяет сохранить результаты и проанализировать их более подробно. 


Команда СВЕАТЕ ТАВГЕ А$ получает результаты запроса ЅЕІЕСТ и строит 
на их основе таблицу. В следующем примере данные союза столбцов 14 1е 
размещаются в новой таблице с именем ту џпіоп. 


Уже знакомый 


Имя новой иладлицы. союз.Тадлица 
р, и соз- 
СВЕАТЕ ТАВІЕ шу џпіоп АЅ абамеся на 


основе любых 
ЗЕТЕСТ &1Е1е ЕВОМ )оь сиггепеЕ ОМТОМ команд ЗЕЁЕСТ. 


ЗЕБЕСТ &1%1е ЕВОМ јор 4ез1геа <” 
ОМТОМ ЅЕТЕСТ Е11е РВОМ јоЬ 1ізбіпдз; ) 


г. Возьми в руку карандаш 


<. 


Создайте союз из столбцов сопкас® іа (таблица јор соггеп?) 
и за1аху (таблица јор _11$Е1п93). 


Как вы думаете, к какому типу данных будет относиться результат? Напи- 
шите команду СВЕАТЕ ТАВІЕ А5 для сохранения результатов союза. 


Выведите описание таблицы командой РЕЗС и проверьте правильность 
своего предположения. 


= (вето на <. 4]9. 
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1МТЕВ$ЕСТ и ЕХСЕРТ 


ІМТЕКЅЕСТ и ЕХСЕРТ 


Конструкции ТМТЕВЗЕСТ и ЕХСЕРТ, в отличие а. Эти две операции 
от ОМТОМ, используются для поиска перекры- ђу дыре НЕ ПО ЕРЖИ 
вающихся результатов запросов. осхооРьжны | а 5 муза 


ІМТЕКЅЕСТ возвращает данные из результатов 
первого запроса, которые также присутствуют И УЕРЕ 
во втором запросе. 


Данные об_сиигелё Данные јор _дезиед. 


> и 


ЅЕГЕСТ біб1е ЕВОМ јор сиггеп® 


ІМТЕВЅЕСТ 


ЗЕЪЕСТ +1%1е ЕВОМ јор 4ез1геа; 


Чилоды данные были 
включены 6 резуль- 


илаил, они должны 
ЕХСЕРТ возвращает только те значения, которые присутству- присцилс илвовдиль 


ют в результатах первого запроса, но не встречаются в резуль- 6 обеих илабли цах 
татах второго. 


Данные јое сиүеи. Данные јор аеѕіғеа. 


ЅЕГЕСТ +іб1е РВОМ јоЬ сиггепе № 
ЕХСЕРТ 


ЗЕГЕСТ &1%1е ЕВОМ јор дезігеа; 


У, 
| 
рый 


Только 

НЕ В олны, Коморые Данные, всилречающиеся 

указанной АЮТСЯ в иладлиие 6 обеих иладлииах, а - 
лос р пе 2 УСБУ. З и : | 

слова ЕХСЕРТ < <ғеЧераго ноился из результаило 
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С союзами разобрались, пора переходить К... 


Погодите, так же нельзя. 
Вы сказали, что союзы и подзапросы дела- 
ют однои то же. Это нужно доказать. 


(Эээ.... То есть мы имели в виду...) 


Сравнение подзапросоВ и соединений 


Практически все, что делается при помощи подзапросов, 
может быть сделано с использованием соединений. Давай- 
те вернемся к началу главы 9. 


ананометьво с поо заграсом 


Подзапросы ДЗа запроса преобразуются В запрое с подзапросом 


Фактнчетаи мы висеть лишь объединием два запроса в один. Пер- 


Чтобы сделать то, что делается двумя запросами, всего в одном запросе, 
вый ЗАПРОХ пазываетуи внешним , а второй — внутренним. 


нам понадобится включить в него подзапрос 


Второй запрос, в котором извлскаются совпадения иэ таблицы 
ргоѓеззіопз, мы назовем ВНЕШНИМ запросом, потому что в него „унако- 


ван» другой, ВНУТРЕННИЙ запрос. Давайте посмотрим, что происходит. 
Е ЗВ ВНУТРЕННЦИ запрос 


= Запрос с подзапросом 


ВИТАС весят нате, славе пате ес ‚рвоте, Зент Еав омм , Яир 
| рвом оъ счттапе 5 јс НАТОВАІ 7019 юу сопкасіз АЗ ас и 
>) ) Ч ЗЕЪЕСТ шс. 1:3 пате, тс.1га* | 
а ДН е ЕВОМ јоЬ соггепё АЗ јс МАТОВАТ, ЈОІМ ту сопбасєз АЗ и 


ИНЕКЕ јс.біЄ1е ІМ (ЅЕІЕСТ бібіе РАОМ јор 1131195) 


рэя сопачет 8 


Все профессии из сииска в скобках были получены в релуль- Подзапрое предетавля- 


тате первого запроса – того, который выбирал все вакантные 
должности из таблицы )о5_соггеле. Таким образом (будьте ет собой запрое «упа- 


Результаты, полученные при вынолнеии этого 
запроса, н точности совпадают © результатами 
при явном перечислении өсех вакансьи н условии 
ИНЕВЕ, но набирать приходится намного меньше. 


внимагельны. это тонкий момент!), мы можем заменить эту 
часть внешнего запроса частью первого запроса. Он по- (а Е 
прежнему вернет результаты, перечисленные в скобках, кованный» в другом 


ыы ЗИЛ Раана запросе. Также ои мо- 


ВНУТРЕННИЙ запрос жет называться «вну- к н.рбеье 
о 1555) 555-3214 


Лонниган 
трепним занроеом». Хиллерман | (555) 555-8976 


ЗЕІЕСТ сібе РАОМ јою 11971095 “ Миллер (555) 555-4443 
мер Колузи (555) 555-5674 [Веб-разработчик, 
Гарза (555) 555-0098 [Веб-разрабогчик 
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использование соединений вместо подзапросов 


Преобразование подзапроса В соединение 


Первый подзапрос, созданный нами в главе 9, выглядел так. 


ЗЕБЕСТ юс.Ғігѕє папе, тюс.1аѕі пате, тс.рһопе, )с.Е11е 


ЕВОМ јор соггепі АЗ јс МАТОКАІ ЈОІМ ту сопёасіѕ А5 пс 
ИНЕВЕ јс.біб1е ІМ (ЗЕЪЕСТ &1Е1е ЕВОМ јоБ 1151195); 


При выполнении запроса был по- Внуилренний 
лучен следующий результат. запрос. 


Веб-дизайнер 


555 Веб-разработчик 
555 Веб-разработчик 


Возьми в руку карандаш 


У Вот как выглядит условие НЕКЕ, если переписать запрос в виде 
© внутреннего соединения. 


ЗЕЪЕСТ шс.Ғігзі паше, шс.1азе пате, шс.рнопе, јс.ііёб1Іе 


ЕВОМ )оь соггепі АЗ јс МАТОВАГ ЈОІМ пу сопфасез АЗ пс 


< 
ІММЕВ ЈОІМ јоЬ 1їзёіпдз 31 Секцин \МНЕВЕ с подза- 
ШЕ < иросом можно заменииль 
внуилренним соединением. 


ОМ јс.бієІе = )1.4141е; ) 


Объясните, почему конструкция ІММЕК ЈОІМ этого запроса возвращает те же результаты, что и подзапрос. 


беа С, 


Какой из двух запросов кажется вам более понятным? 
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Я написал уже немало подзапросов. 
Нужно ли переписать их все в виде 
соединений? 


внешние соединения, самосоединения и союзы 


Нет — если все подзапросы 
делают именно то, что требуется, 
переписывать их не нужно. 


И все же иногда существуют веские при- 
чины В ПОЛЬЗУ того ИЛИ иного выбора... 


Беседа у камина 


Соедцненцае 


Безусловно, я лучше подхожу для большинства 
ситуаций. Меня проще понять и я обычно вы- 
полняюсь намного быстрее, чем какой-нибудь 
старый подзапрос. 


И без вас прекрасно обходились. Прежде все- 
го, меня проще понять. 


Кто бы говорил — как насчет ваших КОРРЕ- 
ЛИРОВАННЫХ и НЕКОРРЕЛИРОВАННЫХ 
разновидностей? 


Соединения и подзапрось: › кто лучше? 


Подзапрос 


Простите, это кто «старый»? Во многих РСУБД 
я не поддерживался до последнего времени. 
Меня пришлось ДОБАВИТЬ, потому что мно- 
гие программисты хотели работать со мной. 


Кого вы пытаетесь обмануть? Поди разберись 
в ваших ВНУТРЕННИХ и ВНЕШНИХ соедине- 
ниях. Напустили туману... 


Хорошо, у нас обоих есть свой жаргон; это 
правда. Но со мной можно сначала вычислить 
внутреннюю часть, а уже потом отдельно за- 
няться внешней. 


— [Рлелжение на следующей странице, 
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беседа у камина 


Беседа у камина 


е 9 


Соеданенае 


Далеко не всегда, мистер КОРРЕЛИРОВАН- 
НЫЙ Подзапрос. Но пока довольно об этом. 

Я лучше подхожу, когда в результатах должны 
присутствовать столбцы из нескольких таблиц. 
Более того, я — единственное решение для по- 
добных случаев. 


Может, это и правда, но разобраться в том, что 
я делаю, не так уж сложно. Вы даже можете вос- 
пользоваться псевдонимами, чтобы вам не при- 
ходилось снова и снова вводить имена таблиц. 


Ага, кое-кто слишком хорош для псевдонимов? 
И если уж вы намного проще меня, то как 
насчет коррелированных подзапросов? Они 
ничуть не проще того, что делаю я. 


Тоже мне достижение. 
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Сегодняшняя шема: соеданеная 
и подзапрросы. Кто лучше? 


Подзапрос 


Да, и именно поэтому у вас нелады с агрегат- 
ными функциями — их нельзя использовать в 
условиях ИНЕВЕ без подзапроса. Согласитесь, 
это отчасти компенсирует запрет на возвраще- 
ние нескольких столбцов. Вы создаете слишком 
много трудностей. 


Да, насчет псевдонимов — мне кажется, что они 
только усложняют понимание запроса. Просто 
для сведения: я ведь тоже могу ими пользовать- 
ся. Но в моем случае это делается куда более 
прямолинейно, причем в половине случаев 
псевдонимы и вовсе не нужны. 


Эээ... верно. Но я знаю как минимум одно, что 
отличает меня от вас. Я могу использоваться 
в командах ОРРАТЕ, ІМЅЕКТ и РЕІЕТЕ. 
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Возьмите запросы с подзапросами из главы Эи посмотрите, что лучше — переписать 
их заново с использованием соединений или оставить подзапросы. 
пражнение 6 зан 


Выведите все должности с зарплатой, равной наибольшей зарплате из таблицы јоь 1і5'іпоз. 


ЗЕ1ЕСТ &161е ЕВОМ јор 1іѕїіпдѕ МИНЕКЕ за1агу = (ЗЕ1ІЕСТ 
МАХ (5а1аку) ЕКОМ јор 1іѕііпдѕ); 


Решение с подзапросами удобнее? 


Выведите имена и фамилии людей с зарплатой выше средней. 


ЅЕТЕСТ тс. Ғігѕё пате, тс.1аѕї пате ЕКОМ ту сопёасізѕ тс 
МАТОВАЬ ЈОІМ јор соггепї јс ИНЕКЕ јс.ѕа1агу > (ЅЕІЕСТ 
АУС (за1агу) ЕКОМ јор сиггеп®); 


Решение с подзапросами удобнее? 
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упражнение. решение 


Возьмите запросы с подзапросами из главы 9 и посмотрите, что лучше — переписать 
их заново с использованием соединений или оставить подзапросы. 


пражнение 
и 
енение 


Выведите все должности с зарплатой, равной наибольшей зарплате из таблицы )ор_11$Е1п9з. 


ЗЕЪЕСТ &1%1е ЕВОМ јор 11ѕііпазѕ МНЕВЕ за1агу = (ЅЕІЕСТ 


МАХ (5а1агу) ЕВОМ ]оЬ 11581195); 


Чилоды запрос возвращал илолько одну 
запись — с наибольшей зарилаилой. 


Выведите имена и фамилии людей с зарплатой выше средней. 


ЗЕТЕСТ тс.Ғігѕё пате, мс.1а5е пате ЕКОМ ту сопіасіѕ тс 
МАТОВАІ ЈОІМ јор сиггепе јс МИНЕКЕ јс.ѕа1агу > (ЗЕТЕСТ 
АУС (ѕаіагу) ЕВОМ јор сиггепе); 


В предыдущем решении мы могли 
2027 использоваиль МІТ: для получения 
Решение с подзапросами удобнее? ..’....:.....”.......... наиболещей зарилаилы из уиорядо- 

ченного списка зарилаил. Зарилаилы 
<быще средней» не уиорядочиваюился, 
поэилому мы не можем использоваиль 
ЫМП для их получения. 
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6 7 
Самосоединение КаК подзапрос и 


ком данного клоуна. 
Вы уже видели, как подзапрос преобразуется в соединение. 


Давайте посмотрим, как самосоединение преобразуется 
в подзапрос. 


с1омп_ЗпЕо 


Элси З 


Помните столбец роѕѕ іа, добавленный в таблицу ре а ый 
с1омп 1пЕо? Вот как выглядело самосоединение, в кото- 
= Зиа] аа нагла 3 0 ИЕ То 
4 

5 

7 
Е 
[10 | 


ром использовались два псевдонима с1оип іпЁо –с1ис2. 


_ Кларабелл Г 0 


гв | 5% | 5 
Мистер Снифлз 


ДО ПРЕОБРАЗОВАНИЯ 


ЅЕ1ЕСТ с1.пате, с2.пате АЅ Бо$$ 
ЕВОМ с1омп 110 с1 < Первый экземиляр 
ТММЕВ ЈОІМ с1оип іпёо с2 сот, 

ОМ с1.Боѕѕ іа = с2.іа; К Виорой экзем- 


иляр сіомми, (ибо. 


ПОСЛЕ ПРЕОБРАЗОВАНИЯ 


Подзапрос, полученный в результате преобразования самосо- 
единения, является коррелированным, потому что он зависит 
от результата внешнего запроса для получения правильного 
значения роѕз іа и находится в списке столбцов ЅЕІЕСТ. 


{А 
вые 
зоғ 


ос. Подзапрос 6 списке 
№ = силолдиов ЅЕГЕСТ. 


7 
\л 


ЗЕБЕСТ с1.паше, А 
(ЅЕТЕСТ паше ЕКОМ с1омп іпёо 
МНЕВЕ с1.Боѕѕ іа 89 АЗ Боѕѕ 


КОМ сіомп іпЁо с1 


` Подзапрос зависиил оил резульилаилов 
бнемнего запроса для получения ира- 


вильного значения Боѕѕ (д, иоэилому 
он являеился коррелированным. 
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ожидать проблем в главе 11? 


Компания Грега растет 


Грег занят изучением соединений и подзапросов. 
Он нанял нескольких друзей, которые должны по- 
мочь ему с менее сложными запросами. 
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Поскорее бы добрать- 
ся до данных Грега. 


Мне нравится моя должность: 
«Начальник по технологиям 
выборки данных». 


Джим У 


Жаль, что новые работники плохо понимают, что 
творят. Вскоре Грег узнает, что происходит при 
одновременной работе с базой данных нескольких 
людей, плохо знающих 501. 
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@: 


А. 


Создайте союз из столбцов сопбасі іа (таблица јор сиггеп\)и за1аку 
(таблица дор 1іѕбіпдз). 


5 ЅЕГЕСТ соглас та ЕВОМ | 


Как вы думаете, к какому типу данных будет относиться результат? Напишите 
команду СКЕАТЕ ТАВІЕ Аб для сохранения результатов союза. 


Выведите описание таблицы командой рЕ5С и проверьте правильность 
своего предположения. 


РЕС(12,2) 


карандаш Со с. 472. 


р {1 ГРЧ 
Решение А вот как выглядит условие ИНЕРЕ, если переписать запрос в виде внут- 
реннего соединения: 


„Возьми в руку 
Ы 


ЕА 


ЅЕТЕСТ шс.Ғігѕзі паше, шс.1азє пате, юс.рһопе, јс.ііі1Іе 
ЕВОМ јор сиггепе АЅ јс МАТОВАІ, ЈОІМ шу сопфасез АЗ шс 
~ 


ІММЕВ ЈОІМ јоЬ 1134198 31 ! Секцию ММНЕВЕ с подзапросом 


можно заменииль Внуилренним 


ОМ јс.бібЛе = ј1.+іб1е; ) СИНИ 


Объясните, почему конструкция ТММЕВ ЈОІМ этого запроса возвращает те же результаты, что и подзапрос. 


Какой из двух запросов кажется вам более понятным? Единсилвенно правильного оилвеила здесь 
дыиль не можейл! Но Ваш оилвеил иоказы- 


какой сиосод будеиле использоваиль 6 бидц- 
щем со своими данными. 
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краткий обзор $54! 


Новые инструменты 


Ваши познания в ЗОЕ стремительно растут. Вы освоили 

внешние соединения, самосоединения и союзы и даже 
знаете, как преобразовать соединение в запрос, и наоборот. 

Полный список инструментов приведен в приложении 11. 


ГЛАВА 10 


РЕФЛЕКСИВНЫЙ ВНЕШНИЙ Е 


Внешний ключ той же 
илаблицы, в Коилорой он 
Ляеился первичным клю_ 


рӯи, используемый для 
РУгих целей. 


ПРАВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ 


Правое внешнее соеди- 
нение передираеил все 
записи ПРАВОЙ илаблицы 
и ищеил для них сооилвеил— 
силвия среди записей 
ЛЕВОИ иладлицы. 


Сиособ посироёний И 
ироса К одной илаблии 


улак, как если бы она 
была двумя иладлицй- 
ми, соде жашщими 
охтон | одинакобую 

ержаи^ информацию. 


| вом 
ключевым со од 


ТЫТЕВЗЕСТ 


Ключевое слово возвращаеи^ 
илолько иле значения, Коло - 
рые присуилсилвуюил 6 первом 
и во вилором запросе. 


Команда, используемая 

для создания иладлицы по 
результатам выполне_ 

Ния команды зЕтЕСТ,. 


ЕХСЕРТ 


Ключевое слово Возвраиаёи 
илолько иле значения, коморот 
ые присуилсивуюил 6 первом, 
но НЕ во вилором запросе. 
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11 (граничения, предстваВвЛенин и хторанзакции 


+ 
У семи нянек * 


Видите, проблема вот здесь — 
вы в графе «количество» 
написали «все сразу»... 


Ваша база данных выросла, и теперь с ней будут работать 
другие люди. К сожалению, далеко не все они так же хорошо разбирают- 
ся в 501, как вы. Вам придется позаботиться о том, чтобы предотвратить 
ввод неверных данных, запретить просмотр лишних данных, а также 
предотвратить возможные конфликты при одновременном вводе дан- 
ных. В этой главе мы займемся защитой данных от чужих ошибок. Итак — 
Защита Ваз Данных, часть 1. 


база данных грега расширяется 


Грег нанимает помощников 
Грег нанял двух работников, и ой 
которые должны помогать ему ( Я уже основательно 


в ведении развивающегося забыл 581... Наде- ) 


Вроде с командами 
ІМЅЕВТ особых слож- 
ностей быть не должно. 


бизнеса. Джим будет заниматься юсь, Грег не заметит. 
вводом данных новых клиентов, 
а Фрэнк — поиском для них под- 
ходящей работы. 


Грег провел предварительный 
инструктаж, на котором объяс- 
нил структуру базы данных 

и назначение каждой из таблиц. 


Ле ситғепф_| оь өзіғей 
сопїасі іа О сопќасїі іа Ож 
йе їе 


есь 
сопќасі_ іа «Әу іпіегеѕі іа Ож 
о 


сопїасїі_ іа бе іпїегеѕї_і9 «у 
[а5{_ пате 0+х 
а 


заїагу Тоту 
ѕїагїі даќе зайагу _ В 


ауаабіе 
уеаг$ _ехр 


ргоѓеззіоп 
ргої іа Ож 


: #гѕї пате 
ргоѓеѕѕіоп – 


роте сопіае зеекіна —звеківв 
сопќасі_іа «у ѕеекіпо іа Оя 

= > 0+ 

Ыгїћаау ы 9 


ого? 1а 88 ѕеекіпо_іа «ур 
= 0+х 


21р_соде & 


Ѕїаќиѕ 1а «= 


тір собо 
ир_соае © 
су 
Ѕїаїе 


мы Шен 


ЅїаїиЅ іа © 
Ѕїаїиѕ 
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Первый день: ВетаВКа данных нового Клиента 


Джим сидит в своем новом офисе и получает сообщение от Грега. 


р > = м = 


- Чат: данные для вставки 
Привет, Джим, можешь добавить запись в базу данных? ў 
( Конечно, могу. х 
6 $ 


Грег 
б Здесь только часть информации, остальное пришлю позже. } Джим 
Грег 


Пэт Мэрфи, 555-1239, райтигрпу@зотеетай.сот, почтовый 
индекс 10087 


Профессия — учитель, семейное положение — в браке не состоит. 
Чтобы получить правильные значения, используй запросы ЗЕЪЕСТ — 
описание синтаксиса найдешь в моих заметках. 


Вроде все просто. Уже делаю :) аА 


© = 


" - =“ Джим 


Не стоит благодарности | 


ЫЗ 


‚с: мозговой 
ТЎ?ШТУРМ 


А вы сможете написать запросы для вставки данных нового 
клиента в базу данных? 
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Джим не хочет использовать МОЕ 


В процессе ввода данных Джим сознает, что 


Я слышал, что значения 


он даже не знает — Пэт это мужчина или о 

МОИ. в базе данных нежела- 
женщина? Грега поблизости нет, решение о 

тельны, но я пока не знаю, 
приходится принимать самому. Джим реша- М 4 

какой пол указывать в этой 
ет ввести в столбце депаег значение «Х». 

записи. 
а 
Он пишет вспомогательные запросы для по- Го Фа 
лучения недостающих данных, например: } РИШ 
М 4 
у: 


Значение ргоѓ ід берется из таблицы ргоѓеѕѕіоп. 


ЗЕЪЕСТ ргоЁ іа ЕВОМ ргоЁезз1оп МНЕВЕ ргоѓеѕѕіоп = 'Учитель'; 


ритор 
аа сооилвемлсилвуюиший 


профессии «ичиилель», 
для последующего ис- 
пользования 6 запросе 
к мц_солЁасїс. 


Значение ѕќаѓиѕ іа берется из таблицы ѕќаќиѕ. 


ЗЕТЕСТ ѕбаїцѕ іа РВОМ ргоѓеѕѕіоп ИМНЕВЕ з®а®и$ " Ы 


Далее Джим создает запись с буквой «Х» в столбце депаӣег. 


Для силолдцов АОТО ІМСВЕМЕМТ задаваиль 
значение не нужно. Два апосилрофа означа- 
юил, Чило значение первичного ключа долж- 


о но генерироваилься абиломаилически. 


ІМЅЕКТ ІМТО ту сопіасіѕ УАБОЕЗ$ ('', "Мэрфи', 'Пэт', 

'5551239', 'раїлогрһуёѕотеетаі1.сот', 'Х', 1978-15-04, 

19, '10087', 3); Ц 

1 / Фикиливное обозначение пола, коило - 
Иденилификаморы, найденные при рое Джим решаеил ввесили В силолдие 
помощи вспомогаилельных запросов. «демдеғ» — он не хочеил Выбираиль 
Также можно было использоваиль наугад или Вводииль МУН. 
иодзаиросы. 
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Три месяца спустя 


Грег занимается сбором демографических данных. Он хочет 
знать, сколько в таблице ту сопфас®$ мужчин, сколько жен- 
щин и сколько всего в ней записей. Для этого он выполняет 
три запроса. 


ЅЕ1ЕСТ СООМТ(*) АЅ Еетаіеѕ ЕВОМ ту сопбас®5 ИНЕКЕ депаег = 'Ж'; 
|__Ретаіеѕ _ Таблица илу солЁасїѕ содержиил 5975 записей 
5975 <— 0 буквой «Ж» В силолдие «демде». 
ЅЕ1ЕСТ СООМТ(*) АЅ Ма1ез ЕКОМ ту сопібасёѕ ИНЕКЕ депаег = 'М'; 


6987 <— И 6982 записи с буквой «М». 


ЗЕТЕСТ СООМТ (*) АЗ Тоа! ЕВОМ ту сопбасіѕ; 
[том Эилоил заир 
ос вВозвращаеил об 
ее 
12970 "^^ количесилво записей 6 илаблице. 


Грег замечает, что сумма не совпадает с общим количеством записей. 
В таблице содержатся 13 записей, которые не учитываются ни первым, 
ни вторым запросом. Он пытается ввести другой запрос: 


ЅЕТЕСТ деп4ег РКОМ ту сопфас®5 
МНЕВЕ депаег <> 'М' АМО депаег <> 'Ж'!; 


Е В поисках пропавших данных он од- 


2 наруживает 15 записей, Ч коморых 
силолбец «демдер» содержиил «Х». 


‚75 мозговой 
СЎГШТУРМ 


Мог ли Джим обойтись без 
фиктивных значений Х? 
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Добавление ограничения СНЕСК 


Ограничения столбцов уже встречались нам в предшеству- 
ющих главах. Ограничение определяет набор значений, 
которые могут вставляться в столбец, и устанавливается при 
создании таблицы. В частности мы уже рассматривали ограни- 
чения МОТ МОІ1, РЕТМАВУ КЕУ, ҒОКЕІСМ КЕҮ и ОМІООЕ, 


Существует еще одна категория ограничений столбцов — так 
называемые ограничения проверки (СНЕСК). Допустим, в базе 
данных должна сохраняться информация о монетках, кото- 
рые попадают в копилку. Копилка принимает только монетки 
по 1, 5, 10 и 25 центов, которые в базе данных обозначаются 
буквами Р, М, Би О соответственно. Следующая таблица ис- 
пользует ограничение СНЕСК для проверки значений, которые 
могут вставляться в столбец сот. 


СВЕАТЕ ТАВІЕ рідду Бапк 
( 


Ограничение СНЕСК 
определяет значения, 
которые могуг ветав- 
лятьея в етолбец 
базы данных. В нем 
используются те же 
уеловные операто- 


ры, что и в условии 
ҮҮНЕКЕ. 


іа ІМТ АОТО ТМУСВЕМЕМТ МОТ МОБ РАТМАВУ КЕУ, 
соіп СНАВ (1) СНЕСК (соіп ІМ ФУ, В, 9) 


) 


Значение 


м силолдиа «сот» можем / 


быиль илолеко одна из эилих бак. 


Если значение, которое вставляется 


в столбец, нарушает условие СНЕСК, { 7 
вы получите сообщение об ошибке. #9 
ульное 


СНЕСК не обеспечи- 
| вает целостности 


‚ остаоРожНы. данных в МуЅа!. 


МУуЅОг позволяет создавать таблицы 
с ограничениями СНЕСК, но эти ограниче- 
ния не работают. Му501 их игнорирует. 
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Ограничение СНЕСК для столбца депйег 


Если бы Грег мог вернуться в прошлое, то он бы создал табли- 
цу ту сопіасіѕ с ограничением СНЕСК для столбца депаег. 
Впрочем, он может решить проблему командой АГТЕВ ТАВІЕ. 


Почему 
я постоянно 
получаю ошибку? 


АГТЕВ ТАВІЕ пу сопфасе$ 
АРрр СОМЗТВАТМТ СНЕСК депаег ІМ ('М','Ж'); 


На следующий день Джим обнаруживает, что он уже не может создать 
запись, в которой столбец депаег содержит фиктивное значение «Х». 
Он обращается с вопросом к Грегу. Тот рассказывает о новом ограниче- 
нии, а поскольку вернуться в прошлое все равно не удастся — поручает 
Джиму связаться со всеми претендентами «Х» и узнать, какого они пола. 


Запишите, какие значения разрешены в каждом из следующих столбцов. 


«; Возьми в руку карандаш 


`` 


СВЕАТЕ ТАВЬЕ туѕёегу аб1е 
( 
со1атп1 ІМТ (4) СНЕСК (со10отп1 > 200), 


со1итп2 СНАБ (1) СНЕСК (со1иџмп2 МОТ ІМ ('х', 
со1итп3 УАКСНАК (3) СНЕСК ('А' = ЗОВЗТВТМС (со1отп З, 


со1итп4 УАВСНАВ (3) СНЕСК ('А' ЗОВЗТВТМС (со1атп_4, 
АМО '9' = ЗОВЗТВТМС (со1иатп_4, 2, 1)) 


Столбец сот оса о Ко ана 


Столбец со от а ева ен аа ес оа а ано 


столбец сот З оа а А Ьа Н таро ол а амала ДАМА 


Столбец: ТА аа а НМ о а аА на Аль 
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возьми в руку карандаш. решение 


“ Возни в руку карандаш 


е Решение 


Запишите, какие значения разрешены в каждом из следующих столбцов. 


СВЕАТЕ ТАВІЕ туѕіегу фаЪ1е 
( 


со1їотп1 ІМТ (4) СНЕСК (со10отп1 > 200), 


со1отп2 СНАВ (1) СНЕСК (со10тп2 МОТ ІМ ('х', 'у", '2')), 


со1оптр3 УАВСНАВ (3) СНЕСК ('А' 


ЗОВЗТВТМС (соїотп 3, 1, 1)), 


со1итп4 УАВСНАВ (3) СНЕСК ('А' ЗОВЗТВТМС (со1атп_4, 1, 1) 
АМО '9' = ЗОВЗТВТМС (со1итп_4, 2, 1)) 


г Разрешены комбинированные 
условия со связками АМР” и ОЁ. 


Столбец со1отп1: 100506 число больше 200 


етн оаа еа 80е еее неене ааа оја ое ае ааневе ао ьо ео а вена аа саваа аана овна набав а ане ааа аа еседа агае ајеа ааа 


= Чааро 
Задаваемые 
Восы 
В: Значит, в СНЕСК можно использовать все то, что раз- не так просты, как ограничения СНЕСК, а тонкости их использо- 
решено в условии ИНЕВЕ? вания выходят за рамки этой книги. 


() Практически все. Вы можете использовать все условные Я р 
конструкции: АХО, ОВ, ІМ, МОТ, ВЕТИЕЕМ ит. д., и даже объеди- • Что произойдет при попытке вставить значение, не про- 
нять их, как в приведенном выше примере. Впрочем, подзапро- ШеДШее проверку СНЕСК? 
сы запрещены. () 

• Вы получите сообщение об ошибке, а данные вставлены 

не будут. 

|: Если ограничения СНЕСК нельзя использовать в МуЅа!., 
то чем их заменить? В: 

* И какая от этого польза? 


(} Простого ответа на этот вопрос не существует. Иногда ис- Я . 
пользуются триггеры — запросы, выполняемые автоматически * Гарантия того, что в таблицу попадут только осмысленные 
при наступлении некоторого события. Но тритеры далеко данные и она не будет забиваться фиктивными значениями. 
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Однообразная работа Фрэнка 


Фрэнк работает над поиском вакансий. Посте- 
пенно он заметил некоторые закономерности: 
вакансий веб-дизайнеров много, а претенден- 
тов — мало. Технических писателей в поисках 
работы много, а вакансий — мало. 


Фрэнк ежедневно выполняет одни и те же за- 
просы, пытаясь подобрать для каждого подхо- 


дящую работу. 


Мне приходится раз за разом 
создавать одинаковые запро- 
сы, и так каждый день. 

Мне это надоело. 


я Фрэнком 


Прелепавьте себя на Местре Фрэнка и напишитре 


запросы, Кетпорые Фрэнк пишет каждый день. 
Папиииихое запрос ДЛЯ Выборки Всех записей Веб — 


дизайнеров из тпабЛчцы Ье 
Вместпе с их КонтрактрньМи даннымМи. 
Шазаинахое АРуГой запрос ДЛЯ поиска 
эткРытых Вакансий ДЛЯ тоехниЧе-— 


ских писатреЛей, 
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с (соввькие терн (завета 


‚5 [реларавьре сеён на Месте Фрэнка и ЅЕГЕСТ илс.ЁеѕЁ мдиле, илс.[а$Е_ 
налишитре запросы, Кошерые Фрэнк маиле, илс.рйоме, илс.еила! 

т =з). на о ЕКОМ илч_соифасЕ$ илс 
аа а МАТИВАЕ ЛОМ јор деѕігед ја 


АЛЯ Выборки Всех записей МУНЕВЕ Ја е = "Вед -дизайнер”; 
Веё дизайнеров из тпаёлЛич— 
цы 2 —Чевть4 ВМестпе с их 
КҠонтрактрньМи данными, [=- 


ЅЕГЕСТ Ще, зааиц, деѕсеірёіои, 
пишитре дрУГой запрос АЛЯ поцска 2ір 


открьшпых Вакансий АЛЯ трехнических ЕКОМ ор 1 (561045 
Й МНЕВЕ йе = “Технический писа- 
писатреЛеч. Й 
мелоб ; 


Запросы несложные, но если Фрэнку придется вводить их 
снова и снова, он почти наверняка совершит какую-нибудь 
ошибку. Ему нужно найти способ сохранения запросов, что- 
бы в один прекрасный день просмотреть результаты, не вво- 
дя запросы заново. 


Пусть сохранит свои запросы 

/ в текстовом файле, а потом 

копирует, когда понадобится. 
В чем проблема? 


Файлы могут быть случайно стерты 
или изменены. 

Существует другой, куда более удобный 
способ сохранения запросов в самой базе 
данных. Для этого запросы преобразуются 
в представления. 
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Создание предстаВления 


Создать представление совсем несложно — достаточно доба- 
вить в запрос ключевые слова СВЕАТЕ УТЕМ. Давайте созда- 
дим два представления для запросов Фрэнка. 


СВЕАТЕ УТЕМ мер деѕідпегѕ Аб 


ЅЕТЕСТ тюс.Ғігѕ пате, шс.1азе пате, тс.рһопе, шс.ета11 


ЕКОМ ту сопіасіеѕ тюс 
=" Также мож 
МАТОВАІ ЈОІМ јор 4ез1геа ја < ^ внутренним соединение 


: І =. Е Е на с условием 
МНЕВЕ ја.+іё1е = 'Веб-дизайнер'; ОМ илс.солёас+ (А 


СВЕАТЕ УТЕМ бесһ мгібег јорѕ АЗ 
ЅЕ1ЕСТ &1%1е за1агу, йеѕсгірііоп, 2ір 
ЕВОМ Јјор 1іѕііпдѕ 

МНЕВЕ &141е = 'Технический писатель’; 


Действительно про- 
сто! Но как использовать 
представление, которое 
я создал? 


с; мозговой 
СУШТУРМ 


Как по вашему мнению выглядит 
команда 501, использующая 
представление? 
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= Ј2.солёась (4. 
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использование запросов в командах ЗЕЕЕСТ 


Просмотр представлений 


Возьмем только что созданное нами представление мер Чез1дпегз. 


СВЕАТЕ УТЕМ мер деѕідпегѕ А5 
ЅЕТЕСТ тюс.Ғігѕі пате, шс.1азе пате, тс.рһопе, тюс.етаіі 
ЕВОМ ту сопёасёзМас СН забывайте: ключевое слово 

нЕ А5 можно не цказываиль. 


МАТОВАТ ЈОІМ јор 4ез1геа ја 
ИНЕВЕ 34а. &1%1е = 'Веб-дизайнер'; 


Чтобы просмотреть текущие результаты представления, мы про- 
сто выполняем с ним операции, как если бы оно было обычной 
таблицей. Например, можно воспользоваться командой ЗЕТЕСТ: 


ЗЕБЕСТ * ЕВОМ иеБ_4ез1дпегз; 


2. 


` Имя иредсилавления. 


Результат: 


напоне | ви еше | 58 | вый | 
5559872 
5556948 


Тодд 5557888 


| 


И илак далее — все залиси, 9 КОТ 
илорых 6 силолбие «Ее» храниился 
значение «Веб -дизайнер»- 
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КаК работает представление 


Представление, используемое в запросе, ведет себя так, словно 
оно является подзапросом. Вот что на самом деле означает толь- 
ко что выполненная нами команда ЗЕТЕСТ с представлением: 


ЅЕГЕСТ * ЕВОМ мер деѕідпегѕ; 


Она означает: «Выбрать все записи из подзапроса, возвращаю- 
щего имя, фамилию, телефон и адрес электронной почты всех 
людей из таблицы ту сопсасіѕ, которые ищут вакансию веб- 
дизайнера». 


ЅЕЦЕСТ * ЕВОМ 


(ЅЕГЕСТ тюс.Ғігѕё пате, тюс.1іаѕё пате, тс.рһопе, мс.ета11 
ЕВОМ ту сопбасіѕ мс 


МАТОВАГ ЈОІМ јор деѕігеа ја 
Е НЕВЕ 94.+1Е1е = 'Веб-дизайнер') АЗ меһ деѕідпегѕ; 


Часиль, ис 
‚ использован - П 
о 
а дзаиросу назначаеился 
исевдоним, чилобы запрос 
инилериреилировал его 
как иладлицу. 


А как насчет этой ча- 
сти — А5 меБ _еѕідпегѕ? 
Зачем она нужна? 


В секции ЕКОМ должна быть 
указана таблица. 
И хотя наша команда ЗЕГЕСТ возвраща- 


ет виртуальную таблицу, 501. не сможет 
узнать об этом без псевдонима. 
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Что такое представление 


В сущности, представление — это таблица, 
существующая только во время использования 
представления в запросе. Представление на- 
зывается виртуальной таблицей, потому что ведет себя как 
настоящая таблица и с ним можно выполнять те же операции, 
что и собычными таблицами. 


Посмотрим на базу данных 
через болшебные очки... 


Но виртуальная таблица не хранится в базе данных. Она созда- 
ется тогда, когда вы используете представление, а затем уничто- | 
жается. Остается только ключевое слово УТЕМ с именем. И это 

хорошо, потому что при каждой вставке новых записей в базу 
данных при использовании представления будет отображаться 2 
повая информация. 5 


Почему представления удобны при работе с базами данных 
_ Возможные изменения структуры базы данных не нарушат работы | 


: Эули илаблице! 
приложении, зависящих от таблиц. 


н й 
: суидеси^оуню“ 


Мы еще не говорили об этом в книге, но через какое-то время вы будете ис-  илолько 60 
2 пользовать свои познания 501. с другими технологиями для создания прило- г в ремя ис- 
: жений. Создавая представления данных, вы сможете изменять базовую структуру : пользования 
: таблиц — созданное представление будет имитировать прежнюю структуру табли- : иредс илавлё ~ 
: цы, и вам не придется вносить изменения в приложение, работающее с данными. : ция 6 заиро- 
ии ео ОИЕ: сах. 


Приложения упрощают сложные запросы до простых команд. 


Вам не придется многократно создавать сложные союзы и подзапросы — до- 
статочно создать для них представление, скрывающее всю сложность ниже- 
лежащего запроса. А когда код 501 будет использоваться в РНР или другом 
языке программирования, вам будет намного проще работать с представлением. 1 
: Вы будете использовать упрощенный код представления вместо большого, слож- 
: ного запроса с множеством соединений. Простота уменьшает вероятность оши- 
: бок, а код станет более удобочитаемым. 


Представления могут скрывать информацию, которая не нужна 
пользователю. 


Предположим, в базу данных агеаз 1ізі добавляются таблицы с данными 
кредитных карт. Вы можете создать представление, в котором будет указано, 
: что данные карты хранятся в системе, не раскрывая ее данных. Работники будут 
: видеть только ту информацию, которая им нужна, а конфиденциальные сведения 
: останутся скрытыми от них. 
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А уменя сложный вопрос. Можно ли создать пред- 
ставление, которое покажет мне всех людей из таблицы 
јоБ_сиггепї, которые также присутствуют в таблице ]оБ_ 
дезге4, с их текущей зарплатой, минимальной желаемой 
зарплатой из поля за!агу_1о\/ и разностью этих двух чисел? 
Проще говоря, насколько они рассчитывают повысить свой 
заработок при смене работы? Да, и не забудьте 
включить их имена, адреса электронной почты 


и р О 


Задача не из простых, но любой запрос, который можно создать в форме ѕЕІЕСТ, может 
пр ажнение быть преобразован в представление. Для начала ответьте на приведенные ниже вопросы, 
а затем запишите запрос Фрэнка в виде представления с именем јор гаіѕеѕ. 


Какие таблицы должны быть включены в запрос? 
Какие столбцы этих таблиц могут использоваться для вычисления прибавки зарплаты? 


Как средствами 581 создать в результатах столбец с именем гаі ѕе? 


Напишите запрос Фрэнка: 
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Задача не из простых, но любой запрос, который можно создать в форме ЗЕТЕСТ, может 
быть преобразован в представление. Для начала ответьте на приведенные ниже вопросы, 
пражнение а затем запишите запрос Фрэнка в виде представления с именем јор гаіѕез. 


оиение 
Какие таблицы должны быть включены в запрос? 


јоб сигем, об_Чеятей и илу.солЕасЕз 


Какие столбцы этих таблиц могут использоваться для вычисления прибавки зарплаты? 


Силолдец <заагу» иладлицы јоб сигем и силолбец <<ва[аиц_[0\/> 
илаблицы јоб деѕікеа 


Как средствами $01 создать в результатах столбец с именем гаіѕе? 


Вычесиль «ѕаіагу» из <вайагу_[ом/>, и назначииль разносили псевдоним. 


Напишите запрос Фрэнка: 


Здесь мы создаем новое пред- 
и силавление с именем јоб _еа1. 


СКЕАТЕ МЕМ јоб ка(ѕеѕ АЅ 


ЅЕГЕСТ илс.Ну$Е мамле, илс. (45 плате, илсетлай, илс.рћоте, 


е . . А вн = 
јс сопфасі іа, јс.ѕаїаку, дату Іом, В осилальном коде запроса ава ФНЧ: 2а. 
| | : илренних соединения испол6зу р 
ее извлечения данных из илрех ма е Е 
| | и я ом & 
РЕКОМ об сигүеиё јс Просилейшая И онр 
ІММЕРВ. ЈОІМ |об_4еягей ја иия создаёил новый силолдец «< | 


(МУМЕВ ЛОМ илу_сомфасё илс о зарилаила Вычиилаетлся 
‹ х А 5 из ожидаемой, 

М/НЕВЕ јс.сомёасё 4 = ј4.солёасі (а назначаеился псебдоне тато 

АМОР јс.солъасё 14 = илс.сотЁасё 1; 


Запрос получился просто огромным, но для просмотра 
информации Фрэнку теперь достаточно ввести простую 
команду 


ЗЕБЕСТ * ЕВОМ јоЬ гаіѕеѕ; 
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— Возьми в руку карандаш 


9 Фрэнк выполняет запрос ЗЕІЕСТ на с. 496 с использованием нового 
Б.ч представления јор гаі ѕез. Как ему упорядочить результаты в алфа- 
витном порядке по фамилиям? 


Г (вет на с. 511. 


ВстаВКа, обновление и удаление В представлениях 


Представления не ограничиваются одной лишь выборкой данных из та- 
блиц. В некоторых ситуациях возможны также операции вставки, обновле- 


ния и удаления данных. 


Значит, я могу 
создать представление, ко- 
торое позволит мне изменять 
содержимое таблиц? 


) 


Можете, но игра не стоит свеч. 


Если в представлении используются агре- 
гатные функции (такие, как $0М, СООЧТ 
или АУС), оно не может использоваться для 
обновления данных. Кроме того, если пред: 
ставление содержит условия СВООР ВУ, 
рІЅТІМСТ или НАУТКЮС, изменение данных 
также невозможно. 


Как правиол, операции ІМЅЕРТ, ОР”РАТЕ 

и РЕГЕТЕ бывает удобнее выполнять традици- 
онным способом, но мы рассмотрим пример 
обновления данных через представление. 
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Обновление данных через представление 


Давайте создадим представление на базе новой таблицы с именем рідду Бапк. 
В таблице хранятся данные о монетках, которые собираются в копилке. У каж- 
дой монетки имеется идентификатор, номинал (первая буква английского назва- 
ния Р №, 0 или ©) и год выпуска. 


СВЕАТЕ ТАВІЕ р19ду_Ъапк 


( 
іа ІМТ АОТО ТМСВЕМЕМТ МОТ МОМ. РКІМАКҮ КЕҮ, 


соіп СНАВ (1) МОТ МЛІ,, 
соіп уеаг СНАР (4) 
) 


В настоящий момент таблица рідду рапк содержит следующие данные: 


Создадим представление, которое выводит только записи 25-центовых 
монеток (О): 


СВЕАТЕ УТЕМ АЗ рЬ аџоагіегѕ 
ЗЕБЕСТ * ЕВОМ рідау Бапк 
МНЕВЕ соіп = '0'; 


с: мозговой 
ШТУРМ 


6.49. 


Как будет выглядеть таблица результатов при выполнении 


следующего запроса? 


ЅЕТЕСТ * ЕКОМ рр аџагіегѕ; 
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Создайте таблицу рідсу рапк, а также представления рр аџагсегѕ ирь_@1тез с исполь- 
зованием приведенных ниже запросов. 
пражнение а е 


ТМЗЕВТ ІМТО рідду рапк УАШЈЕЅ ('','0', 1950), ('','Р', 1972), ('','М', 2005), 
('','О', 1999), ("",'0', 1981), ('", "0", 1940), ("", "0", 1980), ("","Р', 2001), ('','р', 
1926), ("'','Р', 1999); 


СВЕАТЕ УІЕИ рр аџагёегѕ АЗ ЗЕТЕСТ * ЕВОМ рідду рапк МНЕВЕ соіп = '0'; 

СВЕАТЕ УІЕИ рр аітеѕ АЗ ЗЕТЕСТ * ЕВОМ рідду рапк МНЕВЕ соіп = '0' ИТТН СНЕСК ОРТТОМ; 
Поиродийиле поняиль, 
чило делаеил эило Чсло- 


бие, Во Время радоилы 
над упражнением. 


Напишите, что произойдет при выполнении каждого из следующих запросов 
ТМЗЕВТ, РЕІЕТЕ И ОРРАТЕ. В конце упражнения запишите итоговое состояние 
таблицы р1аау_Бапк. 


ТМ5ЕВТ ІМТО рр Чоагёегѕ УАШЈЕЅ ('','0', 1993); 


ТМЗЕВТ ІМТО рр дӢітмеѕ УАШОЕ$ ('','0', 2005); 


РЕБЕТЕ ЕВОМ рЫ дцагіегѕ МИНЕКЕ соіп = '№' ОВ соіп = 'Р' ОК соіп = '0'; 


ОРРАТЕ рр аџагсерѕ ЅЕТ соіп = '0' ИНЕВЕ соіп = 'Р'; 
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Создайте таблицу рідсу Балк, а также представления рр аџагіегѕ ирь_а1тез с исполь- 
\ зованием приведенных ниже запросов. 
пражнение о, А 


Јешение 
ТМЗЕВТ ІМТО рідду рапк УАБОЕ$ ('','0', 1950), ('','Р', 1972), ('','№', 2005), 
('','О’, 1999), ('', "0", 1981), ('','р', 1940), ('','О', 1980), ("','Р', 2001), ('",'р", 
1926), ("','Р', 1999); 


СВЕАТЕ УТЕМ рЫ аџагёегѕ АЗ ЗЕЪЕСТ * РВОМ рідду брапк МНЕВЕ соіп = '0'; 


СВЕАТЕ УТЕМ рЬ аӢітеѕ АЗ ЅЕІЕСТ * ЕВОМ рідду Бапк МНЕВЕ со1п = 'Р' ИТТН СНЕСК ОРТІОМ; 
1 
Напишите, что произойдет при выполнении каждого из следующих запросов Поиродийиле мо - 
ІМЅЕВТ, РЕГЕТЕ и ОРРАТЕ. В конце упражнения запишите итоговое состоя- няиль, чило делаеил 
ние таблицы р19ду Бапк. эило условие, во 
З время рабоилы над 
ТМ5ЕВТ ІМТО рр апцагеегз УАГОЕ$ ('','0', 1993); Чиражнением 


Запрос будеил выполнен нормально. 


ТМ5ЕАТ ІМТО рЬ ачагеегз УАШЈЕЅ ('','0', 1942); 


В илаблицу Всилавляеился новая запись, хомля из-за условия 
НЕВЕ эилого вроде ды дыиль не должно. 


ІМЅЕКТ ТМТО рЬ Ч1тез УАТОЕ$ ('','О0', 2005); 


Ошибка из-за условия СНЕСК ОРТІОМ. Данные, 
вводимые 8 предсилавлении, проверяюился по усло- 
виню УМНЕКЕ перед всилавкой. 


рЕІЕТЕ ЕКОМ рь аџагіегѕ ИНЕВЕ со1п = '№' ОВ соіп = 'Р' ОВ соіп = 'р'!; 


Эилом запрос не изменяем содер – 
жимое иладлицы, поиломц чило поиск 
осуищесилвляеился илолько 8 резуль- 
илаилах с сот = ‘©’ 


ОРРАТЕ рр Яџагёегѕ 5ЕТ соіп = '0' МНЕВЕ соіп = 'Р'; 


Ничего не делаеил с илаблиией, 
иомлому чило предсилавление 
рб-диагегѕ не возвращаеил 
значений с сом = Р! 


Итоговое содержимое ила- 
блииы Выглядиил илак: 
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Представление с СНЕСК ОРТІОМ 


Условие СНЕСК ОРТТОМ, включенное в представление, указывает ва- К 
шей РСУБД, что все команды ТМЗЕВТ и РЕЪЕТЕ должны проверяться онетрукция 


по условию НЕКЕ в вашем предсталвении. Итак, как СНЕСК ОРТТОМ 

влияет на команды ТМЗУЕВТ и ОРРАТЕ? СНЕСК ОРТОМ 
При использовании СНЕСК ОРТТОМ в предыдущем упражнении по- проверяет каждую 
пытка выполнения ІМЅЕКТ отвергалась, если данные не соответство- 

вали условию ИНЕКЕ в представлении рр дітез. Попытка выполне- Я 
ния ОРРАТЕ тоже приведет к ошибке: ПОПЫ у выполне 


НИЯ вставки ИЛИ 
ОРРАТЕ рЬ А1тез ЗЕТ соіп = 'х'; 


обновления данных 


Значение 'х' не соответствует условию ИНЕКЕ в рр аітеѕ, 


поэтому данные не обновляются. на соответствие 


условию \УНЕВЕ 
предетавления. 


Нельзя ли использовать представ- 

ления с СНЕСК ОРТІОМ для создания 
чего-то наподобие СНЕСК СОМ$ТВАТМТ, 
если вы работаете с МузСЕ? 


Да, представления могут точно имитировать таблицы, 
но проверять команды ІМЅЕКТ на соответствие 
условиям УМНЕВЕ. 


Вспомните «проблему пола», о которой говорилось ранее в этой 
главе — на базе таблицы ту сопёасіѕ можно создать представ- 
ление, которое Джим будет использовать для обновления му _ 
сопфасе$. Представление будет выдавать ошибку каждый раз, 
когда Джим попытается вставить'х' в столбец депаег. 


‚0 мозговой 
В Му50)І. можно СУ ШТУРМ 


имитировать СНЕСК Как создать для ту сопёасіз представле- 


ние, которое заставит Джима ввести в поле 


СОМЅТВАІХТ при ПО- депаег либо 'м', либо 'ж'? 
мощи СНЕСК ОРТТОМ. 
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ПредстаВление может быть обнобляемым, если... 


В примере с таблицей р199у рапк оба созданных нами представ- 
ления были обновляемыми. Обновляемое представление позво- 
ляет изменять таблицы, на которых оно основано. Важно, чтобы 
обновляемое представление включало все столбцы МОТ МО из 
своих таблиц. В этом случае при вставке с использованием пред- 
ставления можно быть уверенным в том, что каждый столбец, кото- 
рый обязательно должен быть заполнен, получит свое значение. 


По сути это означает, что с созданными нами представлениями 
могут выполняться все команды: ІМ№ЅЕКТ, ОРРАТЕ и РЕТЕТЕ. Если 
в представление включаются все столбцы МОТ МОГ, оно сможет 
предоставить все необходимые данные для своей таблицы. 


Также существуют необновляемые представления, в которые 
включаются не все столбцы МОТ МОТ... Кроме создания и удаления, 
с необновляемыми представлениями может выполняться только 
операция выборки. 


в представлениях. 


Верно, представления довольно редко 
используются для выполнения команд 1М$ЕВТ, 
ОРОАТЕ и ОЕІЕТЕ. 


Хотя у них имеются свои полезные применения (например, 
обеспечение целостности данных в МубОГ.), обычно проще 
использовать ТМ5ЕВТ, ОРОАТЕ и РЕТЕТЕ с самой таблицей. 
Вставка в представлении может пригодиться в том случае, ес- 
ли в нем выводится только один столбец, а остальные столбцы 
заполняются МО или значениями по умолчанию. В таких 
случаях ТМЗЕВТ может иметь смысл. Также можно включить в 
представление условие МНЕВЕ, которое ограничивает вставля- 
емые данные, имитируя ограничение СНЕСК в Му5ОГ. 


А если вам еще недостаточно сложностей, то учтите, что 
обновление возможно только для представлений, не содержа- 
щих агрегатных операторов (50М, СООМТ, АУС ит. д.), а также 
таких операторов, как ВЕТМЕЕМ, НАУТМС, ТМ и МОТ ІМ. 
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Если не считать СНЕСК ОРТІОМ, я не вижу 
особой пользы от использования ІМЅЕВТ 


Обновляемое пред- 
ставление вклю- 
чает вее столбцы 


МОТ МОШ. из 
евоих таблиц. 


транзакции для всех 


Когда хорошая база данных плохо Ведет себя 


Миссис Хамфрис хочет перевести 1000 долларов 
со своего текущего счета на сберегательный счет. 
Она направляется к банкомату... 


Она проверяет баланс своих счетов, текущего 
и сберегательного. 


1000 5НПОЕЕЯМ$ 30 ЅЯПОГЕЯМ5 
ІЛ НЕСК ІМ ЅЯИІМО5 


Она выбирает. 


ТЕАМСРЕЮ 1000 ЅЯАПОГЕОМ5 
ЕКОМ СНЕСК!Мб ТО 5ЯИ1Мб5 


Она нажимает кнопку. 


Питание снова включилось. 


с Н Е С Е ПЕ ._а 8? м б 5 Она проверяет состояние своих счетов. 


еб у у 0 ЅЯЛОІЕЯМ5 30 5ЯП0ІЕЯМ5 


ами Миу И ІМ СНЕСКИМ 1 59/1155 
д? 
(= 
Банкомат жалобно пищит, и экран гаснет. 


Сбой питания. 
Куда же испарились деньги миссис Хамфрис? 
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Когда какое-либо представление становится ненужным, уда- 
лите его командой ОВОР УТЕМ. Это делается очень просто: 


РВОР УТЕМ рр дітеѕ; 


Частпо 


алаВаеМъые 


Восы 


О > 
}: Можно ли получить список созданных представлений? 


|: Представления хранятся в базе данных как таблицы. Коман- 
да ЗНОМ ТАВГЕ$ выводит информацию обо всех представле- 
ниях и таблицах. А для просмотра структуры представления, 
как и для просмотра структуры таблицы, используется команда 
рЕ$С. 


* Что происходит при удалении таблицы, использованной 
в представлении? 


[; Возможны разные варианты. Одни РСУБД разрешают 
использовать представление, не возвращая данных. Му СЕ 
позволяет удалить представление только в том случае, если 
таблица, на которой оно основано, существует, хотя при этом вы 
можете удалить таблицу, задействованную в представлении. 

В других РСУБД реализовано другое поведение. Поэксперимен- 
тируйте со своей РСУБД и посмотрите, что получится. В общем 
случае представления лучше удалять до удаления таблиц, на 
которой они основаны. 


‚ Ограничения СНЕСК и представления очень полезны 
в тех случаях, когда с базой данных работает сразу несколь- 
ко людей. Но что произойдет, если два человека попытают- 
ся одновременно изменить один столбец? 


О 

() Чтобы ответить на этот вопрос, необходимо познакомиться 
с транзакциями. Но сначала мы узнаем историю миссис Хам- 
фрис, которой понадобилось получить деньги в банкомате. 


Ограничения СНЕСК 

и предетавления помогают 
сохранить контроль над 
базой данных при одновре- 
менной работе нескольких 
пользователей. 
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Что произошло с банкоматом 


Здесь произошел 
сбой пиилания. 


ГШТУРМ 


‚2 мозговой 


БАНКОМАТ: 09-09-4Я... 


БАНКОМАТ: ДЯ 3Т0 НЕ ПИССИС ЭТЕМЬ ХЯПФфРИСІ ПРИВЕТ. ПИС - 
СИС ХВПФРИЕГ СВССОИМТ_10 = 38221] 


Миссис Хамфрис: Скажите, сколько у меня денег. 


БАНКОМАТ: Думает (5ЕТЕСТ ВЯІЯМСЕ РЕКОМ СНЕСК!Мб ШНЕВЕ 
ЯССОЦМТ _10 = ЭВеет: 
СЕЕЕСТ ВЯІЯМСЕ ЕВОП $5ЯИ| №65 ШНЕКЕ НСЕСОИМТ _10 = 30221: ) 


1000 НН ТЕКУЦЕП СЧЕТУ. 38 НЯ СБЕРЕГВТЕЛЬНОЙ 


Миссис Хамфрис: Переведите 1000 долларов с текущего счета 
на сберегательный. 


БАНКОМАТ: ЭВДЯЧЯ НЕПРОСТАЯ. ПИССИС ХЯПФРИС. НО 9 
СПРЯВИЮСЬ... 
ГСНЕСКІМС_ВЯІ › 108080. ДЕНЕГ ДОСТАТОЧНО] 


(СНЯТЬ 1000 С ТЕКУЩЕГО СЧЕТА! 
{ПОНВИУИСТЯ. ВСТЯВЬТЕ БИИИИП...] 


БАНКОМАТ: 
БАНКОМАТ: 
БАНКОМАТ: НННИН 


БАНКОМАТ: ДЯ 3Т0 НЕ ПИССИС ЗТЕЙЬ ХЯПФРИСІ ПРИВЕТ. ПИС - 
СИС ХЯРФРИС ГВССВИМТ_10 = 39221] 


Миссис Хамфрис: Скажите, сколько у меня денег. 


БАНКОМАТ: Думает (5ЕЕЕСТ ВЯЕЯМСЕ ЕЮОП СНЕСК! Мб ШНЕВЕ 
ЯССОИМТ _10 = 38ее1: 
СЕЕЕСТ ВЯЕЯМСЕ РЕКОМ 5ЯИ| №65 ШНЕВЕ ЯССОИНТ _10 = 30221:] 


0 НЯ ТЕКУЦЕП СЧЕТУ. 30 НЯ СБЕРЕГНТЕМЬНОЙ 


БАНКОМАТ: 
ВИ! РАЗВЕ ПОННО БИТЬ БУИНКОЙ ПО ЭКРВНУР 40 СВИДАНИЯ. ПИС - 
СИС ЭТЕМЬ ХЯПФРИС. 


Можно ли сделать так, чтобы банкомат 
не забыл о команде тм5ЕВТ, выполняемой 


в начале операции миссис Хамфрис? 


А тем временем в другом месте... 
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транзакции для всех, часть вторая 


Новые неприятности с банкоматами 


Джон и Мэри имеют общий счет в банке. В пятницу они одновременно под- 
ходят к двум разным банкоматам и каждый пытается снять 300 долларов. 


_ ави — 


151 Мабопа! | | 
баутрз і 


База данных с инфор - 
Мацией о сосилоянии 
общего счеила Мэри 

и Джона. 


{ 


БАНКОМАТ: ПРИВЕТ. ДАНОН. СНОВЯ Тир БАНКОМАТ: ПРИВЕТ. П3РИ 


АЧПАЕШЬ. У ПЕНЯ ДЕНЬГИ ИНИНИЕР 
Мэри: Сколько денег на моем 


Джон: Сколько денег на моем счету? счету? 

БАНКОМАТ: Думает (5ЕТЕСТ БАНКОМАТ: Думает БЕЕЕСТ 
СНЕСКІМО ВАГ ЕЮКОП ЯССООМТС: ) СНЕСКІМО ВАЕ ЕЮОП ЯССООМТС: ) 
350 Д0ЛИВРОВ 350 Д0ЛЛВРОВ 

Джон: Дай мне 300 долларов. ДЗЫНЬ ДЗЫНЬ 

БАНКОМАТ: ТНЯТ'5 яг У0и ТНМК [0 Мэри роется в сумочке в поисках 
ЧОСТ И5Е ПЕ ЯМО ТНЕМ 16 МОВЕ ПЕ. 

ТОЛЬКО И ЗНВЕШЬ. ЧТО ДЕНЬГИ ИЗ ПЕНЯ Мэри: Дай мне 300 долларов. 


ТАЩИТЬ. ПРИШЕЛ. ВЗЯЙ - И ПРОПЯЙ. 
БАНКОМАТ: ЗЯПРОСТО0. 


А 
[СНЕСКІМБ.ВЯІ› 308. ДЕНЕГ ДОСТАТОЧНО] 350 долларов 


6 (СНЕСКІЋ _ВЯЕ > 300. 5НЕ НЯб 
350 долларов | суон понЕЧ) ГСНЕСКІЛБ ВЯ > 


300. ДЕНЕГ ДОСТАТОЧНО] 


(СНЯТЬ 388 СО СЧЕТА] 


(5ЗУВТЕЯСТ 300 РКЕОПСНЕСЕ! Мб _ВАІ) 


[ЧПЕНЬШИТЬ снескІб вяі ня 300} _ 59 поппаров [СНЯТЬ 300 СО СЧЕТЯ] 


Джон забирает денъги и уходит. -250 долларов 
Продлема 
БАНКОМАТ: ПОК. ДЮОН. ЗВОНИ. Возникла 


ГУПЕНЬШИТЬ СНЕСКІМБ ВЯ НЯ 300] 


БАНКОМАТ: 5 ВЯС БОЛЬШОЙ 
здесь. ПЕРЕРЯСХОД. 
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А как было бы замечательно, 
если бы серию команд 501 можно 
было выполнить как единое целое, 
все сразу? И если что-то пойдет не 
так, то вся серия отменяется, словно 
ее и не было? Но конечно, это толь- 
ко мечты... 


дальше » 507 


анатомия транзакции 


Это не мечты, а транзакции 


Транзакция представляет собой набор команд ЗОГ, вы- 
полняемых как единое целое. В случае миссис Хамфрис 
транзакция состоит из всех команд 501., необходимых для 
перемещения денег с текущего счета на сберегательный. 


И | Если баланс текущего счета >= 1000 
. Уменьшить баланс текущего счета на 1000 
Три операции обра Зил Е Увеличить баланс сберегательного счета на 1000 


они единицу рабоилы. И Я 
мо ц есиль илранзакиия. 


Джон и Мэри пытаются одновременно выполнить одну и ту 


же транзакцию. 
Е Джон и Мэри одновременно иыила- 
‚юился снять ио 500 долларов. 


( Если баланс текущего счета >= 300 Если баланс текущего счета >= 300 

7 | Уменьшить баланс текущего счета на 300 | Уменьшить баланс текущего счета на 300 
| Выдать 300 долларов Выдать 300 долларов Г 
КИ О РН И ИР ОИ о едат. р. 


Транзакция 
Баланс Мэр и: 
350 доляаров 


Банкомат Мэри вообще не должен обращаться к счету (даже 
для проверки баланса), пока банкомат Джона не завершит 
обработку транзакции и не снимет блокировку с нее. 


Джона. 


Если в ходе транзакции не удаетея выпол- 
нить хотя бы одну операцию, то не выполня- 
етея ни одна операция. 
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Свойства транзакций 


Чтобы набор команд 50| мог считаться транзакцией, он должен обладать че- 
тырьмя свойствами: атомарностью, целостностью, изолированностью и устойчи- 
востью. В английском языке этот набор свойств часто обозначается сокращени- 
ем АСТО (Асотісісу, Сопѕізсепсу, Іѕоіайоп, Рига у). 


— —– —– – ~ –– ББ 


Атомарность 


Завершаются либо все операции, входящие в транзакцию, либо не заверша: | 
ется ни одна. Транзакция не может быть выполнена частично. Деньги мис- 
сис Хамфрис пронали неизвестно куда именно потому, что была выполнена | 
только часть транзакции. 


Е Е ДЕ а За "ча са Г ЧО БЕ Е ЕЕ, е АВ 


Целостность 


Е аыл а а= 5 ОА 
| 


Завершенная транзакция оставляет базу данных в логически целостном со- | 
стоянии. В конце обеих транзакций из наших примеров состояние счетов 
сбалансировано. В первом примере деньги переведены на накопительный 
счет, во втором — выданы наличными, но в обоих случаях ничего не пропало. 


Е ЗИ о деи а Ч И, оды ЗОН сс” сы: с 


Ц 


Изолированность 


Каждая транзакция работает со своим целостным представлением базы дан- 
ных независимо от других транзакций, выполняемых одновременно с ней. | 
Именно это свойство было нарушено в случае Джона и Мэри: банкомат 

Мэри имел доступ к балансу, пока банкомат Джона завершал транзакцию. 
Вместо этого банкомат Мэри должен был вывести сообщение «пожалуйста, | 
подождите — выполняется транзакция» или что-нибудь в этом роде. 


ет НЫ" ко ава Баай сырых” Вы а талац, ураад Т.Ә) әд, "Фики! Улааны, 8 


+ 


Устойчивость | 
После завершения транзакции база данных должна сохранить измененные 
данные, защитив их от сбоев питания или других опасностей. Обычно | 
для этого описание транзакции сохраняется вне основной базы данных. 

Если бы запись о транзакции миссис Хамфрис хранилась отдельно, то ее | 
1000 долларов вернулись бы на счет. 


ОА о 26... Е аи... И рене БОРИНА ШЕ А: 
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управление транзакциями в 59! 


501 помогает работать с транзакциями 


Рассмотрим очень простую базу данных для 
банка. Она состоит из таблицы с данными 
владельцев счетов, таблицы текущих счетов 
и таблицы сберегательных счетов. 


ассоипі_іа «у 
Ба!апсе 


И еще много 
других силолбиов. 


вссоипї іа & 
___ Е 


При работе с транзакциями в $501. 
используются три команды. 


Команда Здесь а начина – 
сооб! еил следииль за в ани Ч 
ЗТАВТ ТВАМЗАСТТОМ; сор (1079, = Нением вашего ко 


нение всех последующих команд ОГ. вплоть 


илранзакиии. 
ЗТАВТ ТВАМЗАСТТОМ отслеживает выпол- 
до выполнения СОММТТ или КОШВАСК. 


Команда 
закрелляеил „> 
СОММІТ · резульилаиле 
4 всего вВыпол- Если резцльилаил вылолне - 
ненного кода. ния кода вас чсилраиваеил, 


вы закрепляеиле изменения 
6 базе данных командой 
СОММП... 


Если все команды выполнены успешно 
и все выглядит хорошо, закрепите изме- 
нения командой СОММТТ. 


Кома; 
ан 
да воз_ или вВыполнииле коман 5 


—— А, И базы ду КОЦШ ВАСК, чилобы 
ВОГТ.ВАСК; на, К сосило.. Вернуиль базу данных к 
уу Начала сосилоянию до начала 
ции. илранзакиии. 
Если что-то пошло не так, команда Ваш код. 
ВКОІІВАСК отменяет все изменения, { Начало 
и база данных возвращается к со- До начала имран - 
стоянию до ввода команды ЗТАВТ илранзакиии. закции. 
ТВАМЗАСТТОМ. $ { 


Изменения вносятся в базу данных только при выполнении команды СОММІТ. 


510 глава 11 


ограничения, представления и транзакции 


КаК должен был работать банкомат 


ПАТАУНТЕ 
ЅАУІМС5 & ГОАМ 


2 р 
Здесь ИРОИЗОНАА 
7 


свои пииланил. 


команда СОММП 
не была вылолнена, 
иоэиломч сосилояние 
базы данных не из - 
менилось. 


БАНКОМАТ: 1Я-1Я-1Я... 


БАНКОМАТ: ДЯ ЭТО НЕ ПИССИС ЗТЕЙЬ ХЯПФРИСІ ПРИВЕТ. ПИС- 
СИС ХВПФРИС (ВССОИМТ_10 = 38221] 


Миссис Хамфрис: Скажите, сколько у меня денег. 
БАНКОМАТ: Думает (5ЕЕЕСТ ВЯЁЕЯМСЕ ЕВОП СНЕСК!Мб ШУНЕЮЕ 


ЯССООМТ _10 = 38221: 
СЕЕСТ ВНЕЯНСЕ ЕЕОП 5ВИ!М65 ШНЕРЕ ЯССОИМТ_10 = 38еет1:} 


1000 НЯ ТЕКЧЦЕП СЧЕТУ. 38 НВ СБЕРЕГАТЕМЬНОЙ 


Миссис Хамфрис: Переведите 1000 долларов с текущего счета 
на сберегательный. 


БАНКОМАТ: ЗЯДЯЧЯ НЕПРОСТАЯ. ПИССИС ХЯЛФРИС. НО Я СПРАВ- 


ПЮСЬ... 
[5 ТАЮТ ТЕЯМЅЯСТІОМ: 


[5ЕІ ЕСТ ВЯАІЯМСЕ ЕВОП СНЕСВИМС ШНЕРЕ ЯССОИМТ_10=30821] 


БАНКОМАТ: 1000 НЯ ТЕКУЦЕП СЧЕТУ. ПОННО ПРОДОИНЯТЬ. 


БАНКОМАТ: [ ИРОЯТЕ СНЕСКІМб 5ЕТ ВПІ ЯМСЕ = ВПІ ЯМСЕ - 12202 
ШНЕРЕ ЯССОИЋТ 10 = 3802021] 


[ПОНВИУИСТВ. ВСТАВЬТЕ БИИИИП...] 


ВКЕИЮЧВЕТСЯ РЕЗЕРВНОЕ ПИТАНИЕ: ОТПЕНЯ ТРАНЗАКЦИИ 


БАНКОМАТ: 
БАНКОМАТ: 
БАНКОМАТ: ИНИН 


БАНКОМАТ: 48 ЭТ0 НЕ ПИССИЕ ЭТЕМЬ ХЯПФРИСІ ПРИВЕТ. ПИС - 
СИС ХАПФРИС ІАССПОМТ 10 = 38221] 


Миссис Хамфрис: Скажите, сколько у меня денег. 


АТМ: Думает БЕЕЕСТ ВНЕЯМСЕ РЕОП СНЕСКІМб ШНЕВЕ 
ЯССОИМТ _10 = 38221: 
СЕЕЕСТ ВЯЕЯНСЕ ЕВРОП $5ВНУ!Нб5 ШНЕРЕ ЯССОШИТ _10 =382271: } 


“№ 1000 НЯ ТЕКУЦЕП СЧЕТУ. 38 НА СБЕРЕГВТЕМЬНОЙ 
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Как работать 
[Я транзакциями 8 Муз ОЕ Команда для зкономии Времени 


Взгляните на код. который использовался для создания таблицы на с. 217, 
и призелеипый ниже результат выполнения команды ЗНОМ СВЕАТЕ 


проектирование таблиц 


Чтобы использовать транзакции ТАВІЕ ту_соптастз. Эти фра менты нс идентичны, по если вставить 
этот код в команду САЕАТЕ ТАВІЕ, результат будет тем же. Удалять обрат- 
в МУбОТ, необходимо выбрать пра- тааныла А 
вильное ядро хранения данных. Так { 
сна мъ 4:6 и алада, Т1 
называется механизм, обеспечивающий Энни символы трыс арин рн осулроф 
СЕҒРАТЕ ТАВ! р е Ном 
о —— . Бил, ЧАИ 
хранение всей информации и структур О. я К ИНЕт 
базы данных. Одни типы ядер поддер- аспаса манин инициализи > 
а ( рибился зчанернемі 
живают транзакции, другие их не под» `1азЕ паше` уагсваг(30) деғашіє МЫЦ, ие зна. 
держивают. `Е1г5© Маще` уагсһаг (20) аеёаз1е МЛ, чение). 
`еща11` уагсһаг (50) аеёа\11& МОТ, При создани ила - 
Вспомните, как в главе 4 мы рассматри- НЕ ВАР Зета УИ, а тратою 
ЪъігіћҺбау` дае деҒаџ1є МО, 


жет ди силолбеи 
^ргоѓеззіоп` уагсћаг (50) ЧеЕай1+ МІЛІ, содержать МИС. 


`1осаЕ1оп` уагсћаг (50) деҒаџ1є МОЛІ, 
ЅНОИ СВЕАТЕ ТАВІЕ пу сопіасіѕ; `збабоѕ` уагсраг (20) деғао1є МОЦ, 
`іпбегезів` уагсһаг (100) аеҒаціұ МОШ., 
`‘зеекіпд` уагсћһаг (100) аеёаз1е МИ, 


А илеперь выбор ядра Е ) ЕМСТМЕ=МУТЗАМ ОЕРАСІТ СНААЗЕТ=ср1251 


вали результат выполнения команды 


хранения силал дл 7 
и я нас “; 
Ссуиесилвенным. Не обращайиле внимания на 


илексил после закрывающей 


круглой скобки. Он описыва - Еели скопировать и выпол- 


еил механизм хранения данных нить этот код, он еоздает 

и используемую кодировку таблицу. 

символов. Пока нас усилрояйл 

значения по чмолчанию. аа 


Проследите за тем, чтобы 
было выбрано ядро ВОВ 
или ппо0ОВ — только эти 
два ядра поддерживают 
транзакции. 


ое ЕИ ; ИССА 
Е орва араа 
хранения информации. 


: Они называются ядрами хранения данных, и выбор любого 
: из них позволит вам использовать транзакции. За дополни- 
: тельной информацией о различиях между ядрами хранения 
: данных МуЅОТ обращайтесь к документации. 


Для наших целей неважно, какое из двух ядер вы выберете. 
Для смены ядра используется команда следующего вида: 


АГТЕК ТАВІЕ имя таблицы ТУРЕ = Іппорв; 
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Теперь попробуйте сами 


Предположим, мы решили превратить все 
1-центовые монетки в копилке (Р) в 25-центовые (О). 


Попробуйте выполнить следующий код для таблицы 
річчу Бапк, созданной ранее в этой главе. В первой 
транзакции будет использована команда КОІІВАСК, 
отменяющая все изменения. 


ЗТАВТ ТКАМЅАСТІОМ; 

ЅЕІЕСТ * ЕВОМ рідаду рапк; 

ОРРАТЕ рідду бапк ѕеї соіп = '0' мһеге соіп= 'Р'; 

ЅЕЕСТ * ЕВОМ рідду Бапк; <<—— Здесь изменения еще видны. 
ВОБЬВАСК; = Передумали. 


их уже нем. 
ЅЕГЕСТ * ЕВОМ рідду Бапк; < — 2 здесь их Ч 


Второй раз используем команду СОММТТ, потому что из- 
менения нас устраивают. 


ЅТАКТ ТВАМСАСТТОМ; 

ЗЕТЕСТ * ЕВОМ рідаду рапк; 

ОР”АТЕ рідаду БапКк ѕеї соіп = '0' мфеге соіп= 'Р'; 

ЅЕІЕСТ * ЕКОМ рідду Бапк; ——— Здесь изменения еще Видны... 
СОММТТ; = Закрепление илранзакиии. 


ЗЕТЕСТ * РВОМ р199у_БапК; « —— и здесь иложе. 


дальше » 513 


возьми в руку карандаш 


«еси в руку карандаш 


Запишите содержимое базы дан- рідду Бапк 
9 ных р1аау_Ъапк после выполне- 
ния транзакций. Сейчас база дан- 

ных содержит следующие данные. 


ЅТАКТ ТКАМЅАСТІОМ; 
ОРРАТЕ рідду рапк ѕеї соіп = '0' ићһеге соіп = 'Р' 
АМР соіп уеаг < 1970; 


СОММІТ; 


ТАКТ ТКАМЅАСТІОМ; 
ОРРАТЕ рідду Бапк зеф соіп = '№' мпеге соіп = '0'; 
ВОБТВАСК; 


ЗТАВТ ТВАМЗАСТТОМ; 

ОРРАТЕ рідду Ъапк ѕеб соіп = '0' мћеге соіп = 'М№' 
АМО соіп уеаг > 1950; 

КОШВАСК; 


ЗТАВТ ТКАМЅАСТІОМ; 
ОРРАТЕ рідаду рапк зеб соіп = 'р' мһеге соіп = '0' 
АМ” соіп уеаг > 1980; 


СОММІТ; 


бТАВКТ ТКАМЗАСТТОМ; 
ОРРАТЕ рідду бапк ѕеї соіп = 'Р' мһеге соіп = 'М№' 


АМ” соіп уеаг > 1970; 


СОММІТ; 


(зовет на с, 916, 
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: Необходима ли команда ЗТАВТ ТВАМЗАСТТОМ, или 
СОММТТ и ВОБЦВАСК будут работать без нее? 


(} Вы должны сообщить своей РСУБД о начале транзак- 
ции командой ЗТАВТ ТКАМЗАСТІОМ. Это необходимо для 
того, чтобы РСУБД знала, до какой точки следует отменить 
выполненные операции. 


Можно ли использовать ЗТАВТ ТКАМЅАСТІОН 
просто для того, чтобы проверить работу некоторых 
запросов? 


Ы > 
(} Можно и нужно. Это отличный способ поэксперимен- 
тировать с запросами, изменяющими данные таблиц, без 


адаВаеМые 


Вопсь 


Мне все еще нужно придумать, 
как полностью закрыть доступ к некоторым 
таблицам. Скажем, мой новый бухгалтер должен 
работать только с таблицами зарплаты, и толь- 
ко. А еще нужно сделать так, чтобы некоторые 
пользователи могли использовать ЗЕЁЕСТ, но 
операции ІМЅЕВТ, ОРОАТЕ и БЕЕЕТЕ были им 


ограничения, представления и транзакции 


вреда для самих таблиц в случае ошибки. Только не забудь- 
те выполнить СОММТТ или ВОТ.ГВАСК после завершения 
экспериментов. 


В. Нельзя ли обойтись без СОММТТ и ВОГВАСК? 


(} Ваша РСУБД регистрирует все операции, выполняемые 
внутри транзакций, в журнале транзакций; чем больше вы 
выполняете операций, тем больше места занимает журнал. 
Постарайтесь применять транзакции только тогда, когда 
вам действительно необходимо иметь возможность отмены 
выполненных действий, чтобы не расходовать понапрасну 
дисковое пространство, а вашей РСУБД не приходилось 
выполнять лишнюю работу по отслеживанию выполняемых 
действий. 


ЗАПРЕЩЕНЫ. 


Как организовать контроль за доступом 
пользователей к базе данных? 


Об этом вы узнаете в следующей главе. 
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Новые инструменты 


Глава 11 осталась позади, а ваш инструментарий 
практически полон. В этой главе вы узнали, 

как создавать представления для своих данных 

и как выполнять транзакции. Полный список 
инструментов приведен в приложении 11. 


Обновляемое представление 


Предсилавление, коилорое 
позволяеил изменяиль дан- 
ные 6 базовых иладлииах. 
Обновляемые предсилав- 
ления должны содержаиль 
все силолбцы мот мол, своих 


базовых илаблии. 


Транзакция 
Группа команд, вы- 


иолняемых как единое 
целое. Если выполнение 


хоиля бы одной коман- у д 
ды будемл прервано, новляемое представление 
Предсилавлен 


ило оилменяюился сразу Е 
Все команды. | н 
ЗТАВТ ТРАМЅАСТІОМ 


Команда, сообщающая 
РСУБД о начале илран- 
закции. Все дальнейшие 
изменения сущесилву- 
нил лишь временно, 
лока не будеил Вылол 
нена команда соммтт. 
Транзакция продолжаеил 
былолняилься, пока она 
либо не будеил закре- 
илена командой соммтт, 
либо отменена коман- 
дой вотлваск. В случае 


Ограничения проверки 


Ограничения, разрещаю- 
щие всилавку или обнов- 
ление в илаблице илолько 
конкреилных значений. 


СНЕСК ОРТТОМ 


Ключевые слова, ис- 
пользуемые при енти 
едсилав- 
сомони база банных ния, дальнейшие от. 
оя Еа рации всилавки и обнов- 
находилась Эри е | ления ироверяюился на 
с 8 сооилвемлсилвие условию 
аас мневЕ иредсилавления. 
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«Возьми в руку карандаш 


Б“ Решение Фрэнк выполняет запрос ЗЕТЕСТ на с. 496 с использованием нового 
А. Сос. 497 представления јоб гаізѕезѕ. Как ему упорядочить результаты в алфа- 
у А витном порядке по фамилиям? 


Нужно добавииль ОКРЕК ВУ (45 мамле 
либо В команду создания предсилавле- 
ния, либо 6 команду ЗЕТЕСТ ири его 
использовании. 
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‚Возьми в руку карандаш 
ч р ешение, Запишите содержимое базы рідду Ьапк 
РӘ Со с. 514. данных рідаду рапк после 


выполнения транзакций. Сейчас 
база данных содержит следующие 
данные. 


ЅТАКТ ТКАМЅАСТІОМ; 
ОРРАТЕ рідду рапк ѕеб соіп = '0' мћеге соіп = 'Р' 
АМР соіп уеаг < 1970; 
СОММІТ; 


Совладений неил — а зна - 
чиил, нейл и изменений. 


ТАКТ ТКАМЅАСТІОМ; 


І 
о 


ОР”АТЕ рідду Брапк зеё соіп = '№' мһеге соіп 


КОТІВАСК; < — Оулмена, изменений неил. 


ЅТАКТ ТКАМЗАСТТОМ; 


и 
2 


ОРРАТЕ рідду Ббапк ѕеі соіп = '0' мНеге соіп 
АМ соіп уеаг > 1950; 
КОҺ.ВАСК; 4— Оилмена, изменении нёил. 


ЗТАВТ ТКАМЅАСТІОМ; 


ОРРАТЕ рідду рапк ѕеї соіп = '0' мһеге соіп о" 


АМР соіп уеаг > 1980; 
СОММІТ; Измененная запись. 


ТАКТ ТВАМЗАСТТОМ; 


ОРРАТЕ рідду рапк зеё соіп 'Р' мһеге соіп = 


АМР” соіп уеаг > 1970; 


Измененная запись. 
СОММІТ; 
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Защита данных 


А это движение назы- 
вается левым внеш- 
ним соединением. 


Полегче, Декстер — 
у тебя нет необходи- 
мых разрешений. 


Вы потратили массу времени и сил на создание базы 
данных. и если теперь с ней что-нибудь случится, это будет полной ката- 
строфой. Кроме того, вам приходится предоставлять другим пользователям 
доступ к данным и вы опасаетесь, что они могут ошибиться с вставкой или 
обновлением — или и того хуже, удалить нужные данные. В этой главе вы 
узнаете, как защитить базу данных и хранящиеся в ней объекты и как уста- 
новить контроль над тем, какие операции с данными разрешены тем или 


иным пользователям. 


проблемы с вводом данных 


Проблемы с пользователями 


Сбор данных о клоунах в Дейтавиле развернулся 
настолько широко, что городской совет нанял целую 
группу работников для наблюдения за клоунами 

и занесения информации в базу данных с1о\п _ 
Сгаскіпа. 


К сожалению, в группу проник переодетый клоун, 


известный под кличкой «Джордж». Он создал целый ІМУЕЅТ 
ряд проблем в базе данных, включая потерю 


Ѕеситісу ауеюре 
и нежелательное изменение данных, а также почти 9 


совпадающие записи, существующие только из-за 
преднамеренных опечаток. Вот лишь некоторые 
из возникших проблем: 


В таблице сіомп іпѓо имеются записи клоунов с именами Снаглз, Снагглз 
и Снуглз. Мы уверены, что это один и тот же клоун, потому что столбцы 
депдег и дезсирйоп во всех случаях совпадают (различаются только имена). 


Лишние записи в таблице сіомп_іпѓо создают массу проблем с просмотром 
информации. Так, в таблице іпѓо_Іосаёіоп используются идентификаторы 
разных записей Снаглз, Снагглз и Снуглз из таблицы сіомп _іпѓо. 


асііміїу іа Ож 


роѕѕ 9 


Іосаћоп_іа &% 
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Предотвращение ошибок В базе данных 


Джордж уволился до того, как его саботаж был замечен, и нам пришлось 
исправлять причиненный ущерб. Теперь, когда на работу приходят новые 
люди, им необходимо предоставить возможность выборки, чтобы они 
могли опознать клоунов. Но вставка или обновление должны быть запре- 
щены — как и другие операции, пока мы не присмотримся к ним повнима- 
тельнее. 


Также при исправлении ошибок необходимо действовать осторожно — 
если мы разрешим новому работнику удаление данных, он может случайно 
удалить хорошие данные вместе с плохими. 


Настало время защитить базу данных, пока другие клоуны не уничтожили 
ее полностью. 


«_ Возьми в руку карандаш 


Защитите базу данных от возможного саботажа со стороны клоунов. 
Қ. С каждой стороны запишите некоторые запросы, которые должны быть 
разрешены (или запрещены) новым работникам. Там, где это возможно, 
укажите имена таблиц. 


Операции, которые следует разрешить новым Операции, которые следует запретить новым 


работникам. ЕР работникам. 
пример: ЅЁЕГЕСТ Ёоил асіїуіёгеѕ пример: ОВОР ТАВІЕ ом сом ілЁо 


дальше » 524 


возьми в руку карандаш. решение 


Возьми в руку карандаш 


‚ Я Решение Защитите базу данных от возможного саботажа со стороны клоу- 

че. нов. С каждой стороны запишите некоторые запросы, которые 
должны быть разрешены (или запрещены) новым работникам. 
Там, где это возможно, укажите имена таблиц. 


Операции, которые следует разрешить новым Операции, которые следует запретить новым 
работникам. работникам. 


пример: ЅЕГЕСТ Ёгоил асеме$ пример: РКОР ТАВІЕ ой. сои пир 


ЅЕГЕСТ Ёгоил соми и, РКОР ТАВЕЕ ои соми імѓо, тЮ_ 
и_аснугНе$, аси е, аснуНе$, асы Нез, ілЁо _[осаНол, осаной 
мЮ_[осаНой, осадом 


ІМЅЕВТ ои соми. ілЁо, ілЁо асЕіміѓеѕ, 
асїімг1е5, ио_[осанои, Іосаїїоим 


ОР”РАТЕ ои соми іл Ёо, імћЁо асімі!еѕ, 
асе те$, гло (осаіои, [осаНок 


АІТЕВ ом соми и. ѓмЁо_асъімііеѕ, 
аснмгНе$, ілЁо осаіот, Іосатіом 


РЕГЕТЕ ои сои ги, (йЁо асЕмііеѕ, 
асемеѕ, иЮ_[осавои, Іосаом 


Хорошие новости — мы можем помешать 
клоунам уничтожать наши данные! 


ОГ. позволяет управлять тем, какие операции 
разрешены или запрещены тому или иному 
пользователю базы данных. Но сначала не- 
обходимо создать для таких пользователей — 

и вообще всех, кто будет работать с нашей 
базой данных — учетные записи. 
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Защита учетной записи гоо? 


До настоящего момента у нашей базы данных был только один пользова- 
тель, а доступ к ней не был защищен паролем. Каждый, кто мог получить 
доступ к базе через консоль или графический интерфейс, мог делать 

с данными все, что угодно. 


По умолчанию первый пользователь — гооі — может выполнять с базой 
данных любые операции. Это важно, потому что пользователь гоо дол- 
жен иметь возможность создавать учетные записи других пользователей. 
Ограничивать права гоог не нужно, но учетной записи гоо! необходимо 
назначить пароль. В Му5ОГ, это делается следующей командой: 


ЗЕТ РАЅЅИОВЮ РОБ 'гоое'@'1оса1Возе' = РАЅЅИОРР ('54ас10ипй'); 


рей т К 


<< 
Имя иривилегиро- Іосаїлоѕе» указываем, где Пароль, назна - 
Ванного пользова- Чсилановлено и Вылолняеил - ченный иользо- 
илеля — ‘гооР ся программное обесиече_ ваилелю гоо. 
ние $01. 


В других РСУБД используются другие команды. Например, в Огасе 
команда выглядит так: 


а1Еег изег гоої ідепііҒіеа ру новый-пароль; 


Если вы работаете с базой данных через графический интерфейс, 
вероятно, для смены пароля будет намного удобнее использовать 
диалоговые окна. Здесь важно не то, как это делается, а то, что это 
обязательно нужно сделать. 


За информацией о защите учетной записи гоо! обращайтесь к до- 
кументации своей РСУБД. 


часто 
Задаваемые 


ВопЊсь 


* А что означает это «Іосаїпоѕ»? Можете объяснить под- | Аесли я работаю с $501.-клиентом на другом компьютере? 
робнее? 


Г (} Это называется удаленным доступом. Вы должны указать 
(| • 1оса1Поз{ означает, что для выполнения запросов исполь- в запросе местонахождение этого компьютера; в этом случае 
зуется тот же компьютер, на котором установлена РСУБД, Значе- 1оса1поз{ заменяется ІР-адресом или именем хоста. На- 
ние 1оса1һозі используется по умолчанию, поэтому включать Пример, если РСУБД установлена на компьютере с именем 
его в команду не обязательно. Китпдца{$ в сети издательства О’Кей\, то имя будет иметь вид 
гоо@Кимацае$ .оге11]у.сом. 
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Создание нового пользоВателя 


Вопрос, ответ на который вам, вероятно, очевиден: 
Как 5ОГ, хранит информацию о пользователях? 


В таблице, конечно! РСУБД поддерживает базу данных 

с информацией о себе. В таблице хранятся идентификаторы 
пользователей, имена, пароли и сведения об операциях, ко- 
торые пользователю разрешено выполнять с каждой базой 
данных. 


Создание нового пользователя можно начать с имени и па- 
роля. В 501. команды для создания пользователей не суще- 
ствует, но в большинстве РСУБД используются команды 

следующего вида: 
о Имя пользоваилеля 


аа для нашего нового 


рабоилника — Элси. 


СВЕАТЕ ОЗЕВ е151е Зона: 
ТОЕМТТЕТЕО ВУ 'с13у3гр4$5м0га'; деляет синтак- 


сис управле- 


|)7 дыре . 
2  =аперықть] зелето 


Пароль 


Синтаксис команд создания 
пользователей зависит от кон- 
кретной РСУБД. За информацией 
о том, как следует создавать 
пользователей в вашей РСУБД, 
обращайтесь к документации. 


Разве нельзя запретить 
Элси доступ к некоторым 

таблицам при создании 
учетной записи? 


Можно, но иногда мы еще не знаем, какой 
уровень доступа следует предоставить 
пользователю. 


Однако мы все равно должны решить, какая ин- 
формация должна быть доступна для созданного 
пользователя. Все по порядку: сначала вы создаете 
пользователя, а затем предоставляете ему необхо- 
димый уровень доступа. Если вы будете уметь предо- 
ставлять доступ отдельно от создания пользователя, 
то сможете внести изменения позднее при измене- 
нии базы. 
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Решите, что необходимо Каждому пользователю 


Мы создали учетную запись Элси. Пока она не имеет разрешений для выполнения 
каких-либо операций. Чтобы разрешить ей выполнение любых операций с с1оип 
іпЁо (даже простой выборки), необходимо использовать команду СВАМТ. 


В отличие от учетной записи гоог, которой разрешено выполнение любой команды 
ЗОГ с любым объектом базы данных, учетным записям новых пользователей за- 
прещены любые действия. Чтобы разрешить пользователям какие-либо операции 
с базой данных, необходимо выполнить команду СВАМТ. 


моод1апа соЕфаде о Пользоваилели. 


ны = 6 ара" 
а 295) хх Г 
+а1кіпд ‹ | | \ | 
О. 


Ганаа =_= 
о Ген Гу 
аос аореу 


ье [у 
Га 
зане 


2028 = | \ 
=) Л 7 7 


о ея дгитру Варру $ееру ѕпее2у 


Изменение таблицы разрешается только 

некоторым пользователям. 

Новые записи в таблице сһогеѕ могут добавляться только администра: К СВАМТ 
тором базы данных. Только пользователь гоо! может выполнять команды оманда 

ІМЅЕВТ, ОРРАТЕ и ”ЕІЕТЕ для этой таблицы. Пользователь йарру отвечает 

за таблицу ба1 кіп апіта15 и может изменять ее структуру командой точно определя- 


АГТЕК, а также выполнять другие операции. 
ет, какие опера- 


ий 


Выборка из таблицы разрешается только 


некоторым пользователям. ЦИИ е таблицами 
Выборка из таблицы Е а1К1п9_ап1та1$ разрешается всем пользователям, б 
Даже внутри таблиц могут действовать свои ограничения: гут ВЫПОЛНЯТЬСЯ 


некоторые пользователи могут видеть лишь часть столбцов. 


пользователями. 


Все, кроме аореу, могут просматривать содержимое столбца 
іпэігисёіопѕ таблицы спогез. 
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команда СКАМТ 


Простая Команда СКАМТ 


Итак, на данный момент Элси запрещено выполнение каких-либо опера- 
ций. Она может подключиться к РСУБД со своим именем пользователя 
и паролем, но этим все и ограничивается. Чтобы Элси могла выполнить 
команду ЗЕЪЕСТ с таблицей с1оєп іпіёо, ей необходимо предоставить 
соответствующее разрешение. Это делается следующей командой. 


пользователю Разрещаеился 


ыиолнНяиль команду ЗЕЕЕСТ 


СКАМТ ЗЕБЪЕСТ ОМ СТЕ? 
с1іомп іпѓёо е Рлаблицей. 


ТО е151е; <—— Разрешение предо - 
силавляеился пользова- 
илелю с именем еге. 


Элси также необходимо разрешить выполнение ЅЕІЕСТ с другими 
таблицами, чтобы она могла использовать соединения и подзапросы 
в своих командах ЅЕІЕСТ. Для каждой таблицы разрешение предо- 
ставляется отдельной командой СВАМТ: 


СВАМТ ЗЕГЕСТ ОМ асііуіііеѕ ТО е1зіе; 
СВАМТ ЅЕІЕСТ ОМ 1осаііоп ТО е1зіе; 

СВАМТ ЅЕГЕСТ ОМ іпҒо асііуіііеѕ ТО е1зіе; 
СВАМТ ЅЕГЕСТ ОМ 1пЕо 1осаііоп ТО е1зіе; 
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10. 


Упражнение 


безопасность 


Попробуйте предположить, что делают следующие команды СВАКТ для базы данных 
мооа1апа соїсаде (с. 525). 


Команда Что она делает? 


СКАМТ ІМЅЕВТ ОМ тадіс апіта1іѕ 
ТО аос; 


СВАМТ РЕІЕТЕ ОМ сЛлогеѕ 
ТО Һарру, 51ееру; 


СВАМТ РЕБЕТЕ ОМ сһогеѕ 

ТО Һарру, $1ееру 

ИТТН СВАМТ ОРТТОМ; еее 
и _ Подсказка: эмо 

СВАМТ ЗЕТЕСТ (сһоге пате) ОМ ИМЯ силолдиа. ~ 

о 


СВАМТ ЗЕТЪЕСТ, ІМЅЕРТ ОМ 
ба1кіпд апіта1ѕ 
ТО ѕпее2у; 


СВАМТ А1 ОМ ёа1Ккіпд апіта1ѕ 
ТО Баѕһ#01; 


Теперь попробуйте самостоятельно написать несколько команд СВАМТ. 


Разрешить пользователю дос выборку из таблицы 
сПогезѕ. 


Разрешить пользователю ѕіееру удаление 

из таблицы са1 кіп апіта1з, а также разрешить 
Ѕіееру предоставлять разрешение на удаление из 
Са1кіп апітма1ѕ любому другому пользователю. 


Разрешить всем (АТТ,) пользователям выполнение 
любых операций с сһогеѕ. 


Разрешить пользователю 4ос выборку из всех 
таблиц базы данных чоод1ала со+аде. 
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упражнение. решение 


Попробуйте предположить, что делают следующие команды СВАКТ для базы данных 


мооа1апа соёбаде (с. 525). 


ражнение 


аң Команда 
| етение 
1.  СВАМТ ТМЗЕВТ ОМ тадіс апіта15ѕ 
ТО аос; 


2. СВАМТ РЕІЕТЕ ОМ сһогеѕ 
ТО Һарру, $1ееру; 


3. СВАМТ ОЕГЕТЕ ОМ сһогеѕ 
ТО Һарру, $1ееру 
ИТТН СВАМТ ОРТТОМ; 


4. СВАМТ ЗЕТЕСТ (сһоге пате) ОМ 
сһогеѕ ТО аореу; 


5. СКАМТ ЗЕТЪЕСТ, ТМ$ЗЕВТ ОМ 
са1кіпд апіта1ѕ 
ТО ѕпее2у; 


6  СВАМТ АПТ, ОМ Ға1кіпд апіта1ѕ 
ТО БазвЕч1; 


Что она делает? 


Разрешщаеил пользоваилелю 4ос 
Всилавку В илаблицу илавгс_дичила{5. 


Разрешаеил ћарру и 51ееру ————————— 
удаление из илаблииы сиогез. 8 


Разрещаеил ћарру и $еерч удаление из < 
илаблицы сһокеѕ, а илакже предосилав- =—— 


ление другим илого же разрешения. 


Разрешаеил аорец выборку илолько из 
силолбца соге маиле илаблиць соге. а. 


Разрешаеи ѕмееду выборку и всилав- 


ку 6 илаблицу Едікіма_аміилаі. с 


Разрешаеил базиЁи[ выборку, обновле - 
ние, всилавку и удаление с илаблицей 
фаКид_аигила[5. 


Теперь попробуйте самостоятельно написать несколько команд СвАМТ. 


7. ДВАМТ ЅЕГЕСТ ОМ соке 
ТО дос; 


8. ДРАМТ РЕЕЕТЕ ОМ +аікіма_ 
аміила[ѕ ТО 516еру УЛТН аЕАМТ 
ОРТІОМ; 


9. аРАМТ АШ. ОМ сйогез ТО Баз, 


дос, Чорец, дгиилру, ћаррч, 51еерц, 
5иее2ц; 


10. СБАМТ ЅЕЕСТ ОМ мообаиА_ 
соНаде.* ТО дос 
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Разрешить пользователю дос выборку из таблицы 
сһогезѕ. 


Разрешить пользователю $іееру удаление 

из таблицы са1кіпд апіта1ѕ, а также разрешить 
5іееру предоставлять разрешение на удаление из 
Са1кіпд апіта1ѕ любому другому пользователю. 


Разрешить всем (АТт.) пользователям выполнение чай 


любых операций с сћогез. 


РА 


Разрешить пользователю дос выборку из всех 2 — 


таблиц базы данных коод1апа соЕкаде. е 


Разновидности СКАМТ 


В только что выполненном упражнении были представлены 
все основные разновидности команды СКАМТ. Вот они: 


т © 1 \ 


В одной команде СКАМТ можно перечислить несколько 
имен пользователей. 


Всем перечисленным пользователям предоставляются одинаковые 
разрешения. 


Конструкция МТН СКАМТ ОРТІОМ разрешает пользователям 
предоставлять другим разрешение, указанное в команде. 
Описание выглядит крайне запутанно, но по сути означает, что если 
пользователь получает разрешение выполнять выборку из споге$, то 

с ИІТН СКАМТ ОРТІОМ он может также разрешать выборку из спогез 
другим пользователям. 


Вместо всей таблицы можно указать конкретный столбец 
или набор столбцов. 


Пользователю можно разрешить выборку только из одного столб- 
ца. В этом случае содержимое всех остальных столбцов останется 
скрытым от него. 


Для таблицы можно указать более одного разрешения. 


Перечислите предоставляемые разрешения, разделяя их запятыми. 


СКАМТ АСЕ разрешает выполнение операций ЗЕЁЕЕСТ, 
УРОАТЕ, ІМЅЕКТ и ОЕЁЕТЕ с заданной таблицей. 


Фактически это сокращенная запись для перечисления всех опера- 
ций с таблицей. 


Конструкция дайаБазе_пате.* обозначает все таблицы 
в базе данных. 


По аналогии с тем, как * обозначает «все записи» в команде ЅЕІЕСТ, 
эта конструкция обозначает все таблицы в базе данных. 


безопасность 
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команда РКЕУОКЕ 


Команда КЕУОКЕ 


А если потребуется лишить Элси предоставленной привилегии 
ЗЕТЕСТ? Для этого используется команда ВЕҮОКЕ. 


Помните простейшую форму команды СКАМТ? Синтаксис 
ВЕУОКЕ выглядит почти так же, только СКАМТ заменяется 
на КЕУОКЕ, а ТО — на ЕВОМ. 


коилорая оилнима - 


Привилегия, ея (ЅЕГЕСТ). 


ВЕУОКЕ ЗЕТЕСТ ОМ 
с1омп 1пЕо 
„> ЕВОМ е151е; 


Пользоваилель, коилорый 
лищаеился привилегии. 


Также можно отозвать ИТТН СВАМТ ОРТІОМ, оставив саму приви- 
легию неизменной. В следующем примере ^арру и ѕіееру смогут 
выполнять команду ОЕТЕТЕ с таблицей спогез, но не смогут 
предоставить эту привилегию другим пользователям. 


Пользовамель лиилаеи^ся 


илолЬКко привилегии 
{= ЯВАМТ ОРТІОМ. Только попро- 
д буй, Джим, 
ВЕУОКЕ СВАМТ ОРТТОМ ОМ ия НУ тебя всех 


РЕГЕТЕ ОМ сҺогеѕ е це- 
ЕВОМ Һарру, ѕ1ееру; 


Пользоваилели ГА 


по-прежнему и ЗРРУ и веру 


9 привилегию 


Ругим пользобдилелял 


530 глава 12 


безопасность 


Отзыв использованной привилегии СКАМТ ОРТІОМ 


Допустим, пользователь тооѓ предоставил 51ееру привилегию ЕГЕТЕ 
с СКАМТ ОРТТОМ для таблицы сһогеѕ. Пользователь 5/ееру предоста- 
вил 5пее2у привилегию РЕЪЕТЕ для таблицы сһогеѕ. 


—_. —_—_ 

2 иредосилав- ] 
оо  лясил РЕШЕТЕ  чееру иредосилав- ѕпеегу 
для соке ляеил РЕГЕТЕ 
с СВАМТ для сћогеѕ 

ОРТОМ 


Допустим, пользователь тоо! меняет свое решение и отнимает привилегию 
у зіееру. Пользователь 51пеелу также лишится этой привилегии, хотя непо- 
средственно отозвана она была только у ѕ/ееру. 


= 


и </ееру 
УТА ничего не 
делаеил, но 
$ееру ири- р 
ал Вилегии пер 6 Е. 
РЕіЕТЕ для зееру ряеил сбою ѕпеег2у 
оЛереЕ иривилегию. 


У команды КЕУОКЕ существует побочный эффект: 5пеег) также 
лишается своей привилегии. Чтобы вы могли управлять тем, что 
происходит при отзыве привилегий, в синтаксисе ВЕУОКЕ предус- 
мотрены два специальных ключевых слова. 


ВН 
ШТУРМ 


Вскоре вы познакомитесь с ключевыми словами 
КЕЅТКІСТ И САЅСАГЕ. Как вы думаете, что они 


делают? 
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более точные разновидности геуоке 


САЗСАОЕ и КЕЅТКІСТ 


Существует два способа отозвать при- 


вилегию так, чтобы отзыв не отра- 64 

зился на других пользователях. Клю- 

чевые слова САСАГЕ и КЕЅТКІСТ / 

позволяют более точно указать, кто 7 „р едосилавля- 

должен сохранить свои привилегии гоо вил РЕСЕТЕ для 

или лишиться их. сћокеѕ с ОКАМТ 
ОРПОМ 


5Іееру 


пьяни. 

| 
иредосилав- Ј 
ляеил РЕГЕТЕ ѕпеегу 
для сһогеѕ 


С ключевым словом САЅСАРЕ привилегии лишается заданный пользователь (в данном 


случае ѕіееру), а также все, кому он предоставил соответствующие разрешения. 


ВЕУОКЕ ПРЕГЕТЕ ОМ сһогеѕ ЕРОМ з1ееру САЗСАОЕ; 


р Ы 


> 


и > 


${ееру 
Я лишаеил ничего не 
${ееру при - делаеил, но 
им илегии у леду иле- 
го РЕГЕТЕ для Ѕіееру ряеил свою 
соке привилегию. 


к“ 


> САЅСАРЕ означа- 


д 


] 


ѕпееғу 


вил, чило оилзыв за- 
илронёил не илолеко 
заданного пользо- 
ваилеля, но и всех 
пользоваилелей по 
иепочке. 


С ключевым словом ВЕЅТВІСТ привилегии лишается заданный пользователь, а если 


он предоставил привилегию кому-то еще — выдается сообщение об ошибке. 


ВЕУОКЕ ОЕГЕТЕ ОМ сһогеѕ ЕВОМ $1ееру ВЕЗТВТСТ; 


ҳ 


но ничего 
Ра лыилаеился не выходиил, 
= лиилииль Чееру | потому чило 
а привилегии веру команда илак- 
РЕЁЕТЕ для же заилронеил 
соке 5иеерлц. 


Оба пользователя сохраняют свои привилегии, а т00{ получает со- 
общение об ошибке. Изменение не сохраняется, потому что оно 
распространяется на пользователя 5Пеелу, не указанного в команде. 
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ры 


Л. 


ѕпееғу 


56 


Если лишение 
привилегии за- 
илронеил других 
пользоваилелей, 
команда КЕМОКЕ 

с РЕЅТВІСТ вВыдаеил 
оилибку. 


безопасность 


„ Возьми в руку карандаш 


Кто-то продолжает предоставлять Элси лишние привилегии. На- 
5 пишите команды КЕУОКЕ для возвращения к безопасному уров- 
ню, на котором разрешена только выборка командой ЗЕТЕСТ. 


СКАМТ ЗЕЪЕСТ, ІМЅЕВТ, РЕІЕТЕ ОМ 1осаїіопѕ ТО е151е; 


СВАМТ АІ ОМ с1омп 1пЕо ТО е15ѕіе; 


СКАМТ ЗЕТЕСТ, ІМЅЕВТ ОМ ас®1\161е5 ТО е151е; 


СВАМТ ОЕТЕТЕ, ЗЕТЕСТ оп 1пЕо 1оса&1оп ТО е1ѕіе 
ИІТН СКАМТ ОРТТОМ; 


СВАМТ ТМУЕВТ (1осаііоп), РЕІЕТЕ ОМ 1осаёіопѕ ТО е1зіе; 
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возьми в руку карандаш. решение 


=. Возьми в руку карандаш 
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ешение Кто-то продолжает предоставлять Элси лишние привилегии. На- 
қ. пишите команды КЕУОКЕ для возвращения к безопасному уров- 
ню, на котором разрешена только выборка командой ЅЕТЕСТ. 


СВАМТ ЗЕГЕСТ, ТМЗУЕВТ, РЕТЕТЕ ОМ 1осаііопѕ ТО е151е; 


КЕ\МОКЕ ІМЅЕВТ, ЧРРАТЕ, РЕГЕТЕ ОМ (осаїолѕ ЕВОМ вече. “ 


СКАМТ АІ ОМ с1омп 1пЕо ТО е15ѕіе; / 
КЕУОКЕ ІМЅЕКТ, ОРРАТЕ, РЕРЕТЕ ОМ сомики ЕКОМ =! 


Привилегия 
) ЅЕЕСТ долж - 
/ на осилаилься, 


И и Б 
СВАМТ ЗЕЪЕСТ, ТМЗЕВТ ОМ асбіуібіез ТО е1ѕіе; | ОЭИЛОМу оил 
зываелм не все. 


КЕМОКЕ 1МЗЕКТ ОМ аснунез$ ЕКОМ еіс!е; 


Другой смо - 
соб — снача- 


ла оилозваиль 
СВАМТ РЕЪЕТЕ, ЗЕЪЕСТ оп 1пЕо Іосабіоп ТО е151е все привиле- 
ИТТН СВАМТ ОРТТОМ; гии, а полом 


„А иредосилавииль 
РЕУОКЕ РЕЁЕТЕ ои мЮ_[осаНои ЕВОМ е[5іе САЅСАРЕ; необходимые. 


СВАМТ ТМЗЕБКТ (1осаЕ1оп), РЕІЕТЕ ОМ 1осаііопѕ ТО е151е; 


КЕУОКЕ аВАМТ 1М5ЕКТ(осаном), РЕГЕТЕ ОМ (осаїіоиѕ ЕКОМ еіѕге; 


можно ис- 
Верояилно, здесь с ЭЛ мб И еще силоиил цбедииль - 
иользоваиль ОКАМТ, чил ТУЕ ся 6 илом, чило Элси не 
ла выколняиль выборку и предосилавила другим 


иле привилегии, коилорые 
были предосилавлены ей. 
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: Я все еще думаю о командах 
СВАМТ с именами столбцов. Что про- 
изойдет, если разрешить вставку для 
одного столбца таблицы? 


0) Хороший вопрос. Вообще-то такая 
привилегия будет практически бесполез- 
ной: если пользователь может сохранить 
данные только в одном столбце, он не 
сможет вставить запись в таблицу. По- 
пытка завершится успешно только в том 
случае, если таблица состоит из един- 
ственного столбца, указанного в команде 
СКАМТ. 


М Существуют ли другие, столь же 
есполезные команды СВАМТ? 


. 
(} Почти все привилегии для столбцов 
бесполезны, если они не сочетаются 


с привилегией 5ЕТЕСТ в команде СВАМТ. 


. Предположим, я хочу добавить 
пользователя, которому разрешена 
выборка из всех таблиц во всех моих 
базах данных. Существует ли простой 
способ сделать это? 


. Частро 
адаВаеМые 


Весы 


() Как уже не раз было в этой главе, все 
зависит от вашей разновидности РСУБД. 
В МУЗСЕ глобальные привилегии такого 

рода предоставляются командой вида: 


СКАМТ ЗЕТЕСТ ОМ *.* 
ТО е1ѕіе; 


Первая звездочка обозначает все базы 
данных, а вторая — все таблицы. 


Н Значит, режим САЅСАРЕ исполь- 
зуется по умолчанию для команды 
КЕҮОКЕ? 


() Обычно САЅСАРЕ используется по 
умолчанию, но за подробностями вам сно- 
ва следует обращаться к документации 
вашей РСУБД. 


® Г 

Что произойдет при отзыве при- 
вилегии, которой пользователь не 
обладает? 


® 
• Вы получите сообщение об ошибке, 


в котором говорится об отсутствии СКАМТ. 


Значит, если я хочу предоставить одинаковые разрешения 
пяти пользователям, мне нужно перечислить их через запятую 


в конце команды СВАМТ? 
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* Что произойдет, если два разных 
пользователя предоставят $пее2у оди- 
наковые привилегии, которые отзыва- 
ются гоо{ в предыдущем примере? 


() Здесь начинаются сложности. Одни 
системы не обращают внимания на 

то, какая команда СВАМТ выполнялась 

в режиме САЅСАРЕ, другие игнорируют 
привилегии, предоставленные другими 
пользователями. Это еще одна ситуация, 
в которой ответ следует искать в докумен- 
тации РСУБД. 


: Существуют ли другие объек- 
ты, кроме таблиц и столбцов, кото- 
рые могут использоваться в СВАМТ 
и ВЕУОКЕ? 


() Представления могут использоваться 
точно так же, как таблицы — если только 
представление не является необновляе- 
мым. В противном случае вам не удастся 
использовать ТМ5ЕКТ даже при наличии 
разрешения. И по аналогии с таблицами, 
доступ может разрешаться на уровне 

конкретных столбцов представления. 


Такое решение определенно сработает. И при небольшом 
количестве пользователей действовать нужно именно так. 


Но по мере роста вашей организации в ней будут появляться классы 
пользователей. Допустим, 10 человек занимаются вводом данных 

и им достаточно предоставить разрешения на вставку и выборку из 
некоторых таблиц. Также в системе могут быть три администратора, 
которым разрешены любые операции, и множество рядовых пользо- 
вателей с доступом на уровне ЗЕТЪЕСТ. Возможно даже существование 
программ и веб-приложений, которые подключаются к базе данных 
и работают с конкретными представлениями. 
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чем плохи общие учетные записи 


—. 
Так почему бы не со- 
здать по одной учетной записи 
для каждого класса, чтобы несколько 

(е) ( пользователей использовали одно 
и то же имя с паролем? 


Саймон изменяет пароль 
и забывает сказать об этом 
остальным. Теперь никто 
не сможет работать с базой 
данных, пока Саймон не 
вспомнит об этом. 
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т ВИН 


Рэнди по своей работе должен 
иметь полный доступ ко всем 
объектам базы данных. Из-за 
этого база данных становится уяз- 
вимой для других пользователей, 
которые не так хорошо знают 
ЗОГ и чаще совершают ошибки. 


зћҺагеа ассоопі 7. м 


<----- 


паіп даёараѕе 


7 ШБ 


Проблема общих учетных записей 


Некоторые компании неплохо управляются с об- 
щими учетными записями, которые могут работать 
с базой данных, но это довольно рискованный путь. 
Несколько примеров ситуаций, в которых могут воз- 
никнуть проблемы: 


Пола плохо знает, как пи- 
шутся команды обновления, 
и часто портит данные в базе. 
Но администратор не знает, 
кто именно из пользователей 
внес изменения, и не сможет 
разъяснить Поле ее ошибки. 
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Отдельные учетные записи — 
не лучшее решение для групп поль- 
зователей, совместное использова- 
ние одной учетной записи тоже не 
годится... Что же делать? 


Нужно каким-то образом назначить группам 
их привилегии, одновременно сохраняя за 
каждым пользователем индивидуальную 
учетную запись. 


Для этого нам понадобятся роли. Роль позволяет опре- 
делить набор привилегий и назначить их всем участни- 
кам некоторой группы. Роли становятся объектами базы 
данных, которые можно изменять в случае изменения 
базы — при этом вам не придется явно изменять при- 
вилегии каждого пользователя в соответствии с измене- 
ниями в базе. 


УТ В Муѕа 
Команда создания роли очень проста: ульше | ропи — 
‚ остпорожнь! поддержи- 
: ваются. 
СВЕАТЕ КОШЕ даа епігу; Вероятно, поддержка ролей 


: появится в будущих версиях 
Л : МУЗОСЕ, но пока привилегии 
Имя создаваемой : приходится назначать на 
роли. : уровне отдельных пользова- 
телей. 


Привилегии предоставляются ролям точно так же, как и име- 
нам пользователей. 


СВАМТ ЗЕТЕСТ, ІМЅЕРТ ОМ зоте ёар1е ТО даїа епїгу; 


^ 


Вмесило имени 

иользоваилеля ири 

назначении ириви - 
Мы создали роль и определили ее привилегии. легий указываем - 


Теперь необходимо назначить ее пользователю... ся имя роли. 
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развлечения с ролями 


Чспользование роли 


До создания ролей привилегии пользова- 
телей назначались командой СВАМТ. 


————ь 


А, 


Предосилав - \ 
ТТ ляеил приви- 
гоої легии ЅЕГЕСТ 


дос 

и ІМЅЕКТ Д 

СВАМТ ЗЕЪЕСТ, ІМЅЕКТ для заКид Е 
ОМ ба1кіпд апіта1ѕ ауіила(5. ' 
ТО аос; р" А 
77 ү 


Силарый сиособ. 


+а1кіпя апіта1з 


| атаа | алта! гуре 


Ыџе Ыга 


Остается лишь заменить операцию СКАМТ, указать в ней 
новую роль и применить к 0с. Перечислять привилегии 
или таблицы не нужно, потому что вся информация хра- 
нится в роли даа епігу:. 


СВАМТ даа епігу ТО Яос; 


имя роли занимаей^ 


месило имени илаблииы 
и привилегий. 


гоої 


Удаление ролей 


Когда надобность в роли отпадает, незачем хранить ее в базе 
данных. Удаление ролей осуществляется командой ОВОР. 


ОВОР ВОБЕ даа епігу; 
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часто 
алаБаеМые 


Вопњсы 


: А если я хочу предоставить привилегии для всех ‚ Если пользователь обладает ролью, которая была 
таблиц в базе данных? Перечислять все имена? удалена, он лишается этих разрешений? 


(} Нет, используйте следующий синтаксис: () Вот именно! Все выглядит так, словно вы явно предо- 
ставили ему эти разрешения, а потом отозвали их. Только 
вместо одного пользователя разрешений лишаются все 
пользователи, которым была назначена эта роль. 


СВАМТ ЗЕЪЕСТ, ІМЅЕҺТ, РЕБЕТЕ 
ОМ дгедѕ 1ізі.* 


ТО јіп; 
Достаточно указать имя базы данных, а знак * обеспечит я 
назначение привилегий для всех таблиц этой базы. к Может ли пользователь иметь сразу несколько 
ролей? 
. Ж . 
• Можно ли удалить роль, которая в данный момент () Да, может. Только проследите за тем, чтобы роли 
назначена пользователю? не конфликтовали друг с другом, иначе вы создадите себе 


немало проблем. 


. 

(} Вы можете удалять роли, используемые в настоящее 
время. Будьте очень внимательны при удалении ролей, что- 
бы не лишить пользователей необходимых разрешений. 


— „Возьми в руку карандаш 


, 
% Как отозвать роль 
Роли отнимаются у пользователей почти так же, как и привилегии. 


Удастся ли вам написать команду для отзыва роли даса епігү 
у пользователя дос, не заглядывая на следующую страницу? 


ь. 
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ИИТН АБММ ОРТІОМ 


„Возьми в руку карандаш 


х > 
“е Решение Роли отнимаются у пользователей почти так же, как и привилегии. 
„878 Удастся ли вам написать команду для отзыва роли даса епёгу 
у пользователя ос, не заглядывая на следующую страницу? 


ЁЕМУОКЕ дата елігу ЕКОМ даос; 


Конструкция МИТН АОМІМ ОРТІОМ 


Как говорилось ранее, у команды СКАМТ имеется режим ИІТН СКАМТ 
ОРТІОМ. У ролей существует аналогичная конструкция ИТТН АБМТМ 
ОРТТОМ. Она позволяет каждому обладателю роли назначать ее всем 
остальным. Например, при использовании следующей команды: 


СКАМТ Ааба епёгу ТО 4ос ИТТН АРМІМ ОРТІОМ; 


Теперь 40с обладает привилегиями администратора и может "% ҮМІТН Армім ОРТІОМ 
назначить йарру роль даса епігу точно так же, как она была Разрешаеил лользова - 
назначена ему самому: мел дос Назначииль 
роль ааёа_епіүу любом 
СВАМТ даба епїігу ТО Һарру; другому пользовдиледьт 


При использовании с ролями команда КЕУОКЕ также поддержива- 
ет ключевые слова САЅСАРЕ и ВЕЗТВТСТ. Давайте посмотрим, как 
они работают. 


Отзыв роли с САЅСАВЕ 


С ключевым словом САЅСАрЕ команда ВЕУОКЕ действует не только 
на пользователя, но и на всех остальных пользователей в цепочке. 


ВЕУОКЕ даа епёгу ЕВОМ дос САЅСАГЕ; 
қ 2 С ключевым словом 
САЗСАРЕ команда 
ИГ РЕМОКЕ А не 
Ж ЖЕБРРСЫРЕЕРЕР? <. илолько на пользобаилеля, 
в) но и на всех осилаленых 


ве (\ пользоваилелей 6 цељочке. 
лишаєил 0с гии, комлорые 
роли да+а_ Д иредосилавил й 
еифич. дос ёму 40с. Һарру 


540 глава 12 


Отзыв роли с КЕЅТКІСТ 


Если пользователь успел назначить роль кому-то другому, то при 
попытке лишить его этой роли командой КЕУОКЕ с ключевым 
словом ВЕЗТВТСТ произойдет ошибка. 
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р =, 


ВЕУОКЕ даа епігу ЕВОМ дос ВЕЗТВТСТ; 


х 


Ё? 


лыилаеися Иа, 
лишииль ос Я иил, 
л 9 что 
г оли аа 
90 б рН 99° изменение һарру 
илакже заилро- 
неил Һарру. 


Оба пользователя сохраняют свои роли, а тоо! получает 
сообщение об ошибке. Изменение не сохраняется, потому 
что оно распространяется на пользователя ћарру. 


Роли — удобная штука, но давайте вернем- 
ся к реальности? У меня всего два работника, 

скоро появится третий. Роли мне не нужны, 
но я не хочу, чтобы мой персонал использовал 
учетную запись гоої. Как мне назначить своим 
работникам правильные уровни доступа без 
использования ролей? 


Пришло время заняться настройкой 


ставить им соответствующие привилегии. 


Если лищение роли 
заилронемл других 
полезоваилелей, 


команда ВЕМОКЕ 
с ВЕЅТЕІСТ выдаеил 
ошибку. 


безопасности доступа к базе данных дгедѕ Ііѕ. 


Грег должен выполнить действия, описанные в этой 
главе, и защитить учетную запись то0і, разобраться В ТОМ, 
какой уровень доступа нужен его работникам, и предо- 


А теперь плохая новость: на месте Грега окажетесь ВЫ... 
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стань грегом 


(звань [Регом 


р Последний Раз предстраВьтре себя на Местое [рега и настрой 
тре Разрешения поЛьЗзоВатреЛей, Чтробы неопьпрные Раёотоники 
ниЧеГо случайно не испортили, 


Џрочитайое описания Работы КаждоГо поЛьЗоВатрелн, 
ье Команды СВАМТ. Котрорые предостравятр 
Работникам доступ к необходимым данным 


и не позВоЛято ЧМ сдеЛатрь ниЧеГо ЛишнеГо, 


Фрэнк Фрэнк: Я отвечаю за поиск работников для от- 
крывшихся вакансий. Я никогда не ввожу данные 
в базу, хотя и удаляю вакансии при их закрытии 
или обнаружении претендента. Иногда мне также 
приходится искать контактные данные в таблице 


пу сопвасе$. 


Джим: Я ввожу всю новую информацию во всей 
базе данных. Теперь, когда я не могу случайно 
ввести Х в столбце депаег, у меня все отлично по- 
лучается. Я также обновляю данные и понемногу 
учусь удалять, хотя Грег мне это запрещает. Конеч- 
но, ему я об этом не говорю... 


Джо: Грег только что нанял меня для работы над 
сайтом своей фирмы. Он хочет, чтобы контакт- 
ные данные интегрировались на сайте. Вообще- 
то я веб-программист, а не специалист по 501, 
но я умею выполнять простые команды ЅЕТЕСТ. 
А всякие вставки-удаления — это не для меня. 


рзгляншое на структуру базы данных 
Фев. 1 ч налишитре Команды СПАМ для 


этрих парней, пока они не повредили данные. 
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Шье КоМанду для назначения пароля поЛьЗоВагреЛю с именем «о[у. 


|[впиизитое три Команды, Которые создаютр тири Учетоные записи — по одной ДЛЯ КаждоГо 


мз трех РаботнчКовВ. 


|[апиититое Команды СВАМ. Которые будут назначатрь праВиЛьные Разрешения каждому 
иЗ тррех РаёотаниковВ, 


сопїасі_ іа = 
іпїегеѕї іа «= 
сопќасі_ 19 «у 
ѕеекіпо_іа «Әу 


сопїасі іа Ож 


[ усе _ 


Ыгһаау 
сїаїиѕ_ іа Әу 


сопїасі іа == 


«5-е 


ѕїаг{ аїе 


іпіегеѕї іа О 


___зеекіпв | 
еекіпс_іа Ож 
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стань грегом. ответ 


(звань [регом. (овето 


В последний Раз предстраВьхе себя на Местре | Рега ч настройтре 
разрешения поЛьЗоВатреЛей, Чтробъ неспытаные Раёотоники ничеГо 
ГМ 
случайно не чапертрили. 
Прочитайте описания Работы КаждоГо поЛьзЗоВатпеЛя. 
[впииитое команды СВАМ. Которые преДостпаВятп 
, . ВР». - Раёотоникам доступ К необходимым данным 
2—4 ссем 
"ҹә ШЦ и не поЗзВоЛятр ЧМ сдеЛатрь ниЧеГо ЛишнегГо, 


[пиититре Команду для назначения пароля поЛъЗоВатреЛю с именем «Тор. 


ЅЕТ РАЗЗ\/ОКР РОК гоо@осаозЕ = РАЅ5%У08Ер('аг508и12"); 


Пъшите три Командь, Котпорые создаюта тори Учетаные записи — по одной 


для каждеГо из трех работаниКоВ. Если Ваши па 
р ь роли выглядяил 
СВЕАТЕ ОЅЕВ Ёғамк ІРЕМТІЕІЕР”Р ВУ ОБМАтеН’; иначе — не обращайиле вни- 


Е мания. Главное, 
СВЕАТЕ ЕВ и ІРЕМТІРІЕР ВУ ‘Молот; < фрдеменияи о и 


на месиле и следовали 
п 
6 правильном порядке! 


[[ахиикихое Команды СВАМТ, Которые будут назнаЧатрь праВиЛьные 


Разрешения каждому из тррех РаботанчКэвВ, 


СВЕАТЕ ОЅЕВ {ое ІРЕМТІЕІЕР”Р ВУ ‹51еСт40оОа”; 


Фрэнк должен имеиль возмож ~ 


СР ь чдаляиль вакансии и выпол- 
ЧВАМТ ЕГЕТЕ ОМ јо |ісійтдѕ ТО акк; „НОС бро из илу_солЁасїѕ. 
ЯКАМТ ЅЕГЕСТ ОМ илу_сопасёз * ТО Ёаиі; 
Джиму необходим досилци ЅЕГЕСТ 
Ф “и ІМЅЕРТ ко всем объектлам аге. 


СВАМТ ЅЕГЕСТ, ІМЅЕВТ ОМ аиедз_И5ё * ТО м; (16. А Воил цдаляиль данные ему 
лока рановаило. 


ЯВАМТ ЅЕГЕСТ ОМ илу_соифасё$, ргоЃеѕѕіои, хїр содє, ѕ+аёис, 


солЁасі ілёегеѕ, глёегеѕЕѕ, сопёасі ѕеекіма, ѕеекімд ТО јоє; 


Наконец, Джо нужно разрешиммо выборку 
`` из Всех исходных иладлиц — кроме е. 
комлорыє оилносяился к поискам радоў: 
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Объединение СКЕАТЕ И$ЕК с СКАМТ 


эчсә ке 


Пока мы еще не закончи- 
ли — нельзя ли объединить 


СВЕАТЕ ОЅЕВ с бСВАМТ 
в одну команду? 


Да, можно. Для этого достаточно связать 
воедино две части, которые мы уже видели. 


Вот как выглядели команды СВЕАТЕ О5ЕВ и СВАМТ, 
использованные нами для Элси: 


СВЕАТЕ О5ЕБ е151е 


ТРЕМТТЕТЕО ВУ 'с13уЗгр4ѕ5м0га"'; 


СВАМТ ЅЕІЕСТ ОМ 


сІомп іпёо 


ТО е1з1е; 


Давайте объединим их, опустив часть СВЕАТЕ ОЅЕР. 
Так как пользователь е/5іе должен существовать для 
предоставления ему привилегий, РСУБД сначала 
проверяет, существует ли пользователь с заданным 
именем, и если нет — автоматически создает учетную 
запись. 


СВАМТ ЅЕГЕСТ ОМ 

сіоип іпѓЁо 

ТО е1з1е 

ТОЕМТТЕТЕО ВУ 'с13У3гр4з5и0га'; 
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список грега выходит на мировой уровень 


Озлушительный успех! 


о осво- 
Благодаря вашей помощи Грег так р ане 
ил 501. (а также научил Джима, Фрэнка 


Спасибо, без вас я бы не спрат 
вился! Кстати, у меня открыва- 
ется филиал в вашем городе... 


? 
это стоит обсудить: 
я о Может, 
что в его базу данных была включена поддерж 5 
рекламных объявлений и форумов: за. Р" 
иле 
А знаете, что самоє невероятное? В Дейтав Е. 
, 


х по 
его ждал такой успех, что в более 500 городе 
ирмы Грега, 
лись филиалы ф 
всему миру открь 5 
а сам Грег не сходит с первых страниц газе 


АО бе ВҮЕН < 


Помпи скафреца 


Вакансии и гадан 


Друзья и родственники говорят, что слава ничуть не измени- 
ла Грега. 


Трой Армстронг 
КОРРЕСПОНДЕНТ ІМОЧОЕКҮЕК 


ДЕЙТАВИЛЬ — Местный предприниматель Грег добился 
успеха и известности. Его сетевая база данных превратилась 
из набора карточек сначала в простую таблицу, а потом и в 
многотабличную базу данных со службой знакомств, поиском 
работы и другими полезными функциями. 


База данных Грега уже 
добралась до вашего города? 
Если нет — это вопрос времени, 
говорят аналитики. 


1 546 глава 12 


безопасность 


Новые инструменты 


Поздравляем, вы закончили главу 12! 
Ниже перечислены основные концепции 


безопасности $01, представленные 
в этой главе. Полный список инструментов 


приведен в приложении 11. 


О ҮЧҮ 


СВАМТ 


Команда илочно опреде- 
| Ляёил, какие операции 
Могул Выполняилься 
полЬзоваилелем с ила 


ле 
команда у А для блицами и силолб, №: 
екомлоро Ме ии са соба предо- 
дания 9 ИА" эленных ему ирибви- 
| сЕ ле ря, легий, 9 ириви 
значени Р 
МІТН СВАМТ ОРТІОМ 
Разрешаёи пользоваиле - 
лю даваиль другим поль- 
ке- | зоваилелям иредосилав- 
да ^ МА ленные ему привилегии. 
н билеги“ 
Кома и 
ля 


ИТТН АРМТМ ОРТТОМ 


Разрещаеил лользоваиле – 
лю назначать другим 
пользоваилелям соб- 
ственную ему роль. 


дальше » 547 


спасибо, что посетили Деитавиль! 


Присоединяйтесь! 


Ого, реклама фирмы 
Грега идет во время 
Суперкубка! Путь был 
долгим, но каков успех! 


Используйте $01 В своих проектах... 
и Возможно, Вас тоже ожидает успех! 


Мы были рады встретиться с вами в Дейтавиле. 
Жаль, конечно, что нам приходится расставаться, но пришло 
время применить полученные знания на практике — наверняка 
где-нибудь вблизи от вас есть клоуны, за которыми нужно наблю- 
дать, пончики, которые нужно попробовать, или Список [подставьте 
ваше имя], который нужно создать. В конце книги вы найдете еще 
кое-какую полезную информацию и алфавитный список основных 
инструментов 501 — а потом беритесь за дело! 


[Рележение |. [[речее 
є 


Десять важнейших тем * 
(о которых мы не рассказали) 


Но даже после всего сказанного беседа еще не за- 
кончена! Есть еще кое-что, о чем вы должны знать. Мы решили, 
что будет неправильно просто проигнорировать эти темы — они 
заслуживают хотя бы краткого упоминания. Итак, прежде чем от- 
кладывать книгу, ознакомьтесь с этими короткими, но важными 
разделами. А когда вы прочитаете и эту главу, останется еще 
пара приложений... и может быть, немного рекламы... и ничего 
больше. Честное слово! 


графический интерфейс 


1. Цепользуйте графический интерфейс К своей РСУБД, 


Безусловно, очень важно уметь напрямую выполнять команды ОЕ. из консоли, но 
к этому моменту вы уже достаточно хорошо понимаете, как это делается. И конеч- 
но, вам хотелось бы иметь более простой способ создания таблиц и просмотра их 
содержимого. 


У каждой РСУБД имеется свой графический интерфейс. Далее приводится крат- 
кая сводка графических инструментов Му ОГ. 


Графические инструменты Муз ОЕ 


Вместе с МуЗОГ, также можно загрузить графический инструментарий Му5ОГ,, 
и что еще важнее — программу Му5ОГ. Аатіпіѕггаѓог. Весь пакет доступен по адресу: 


Һер: //аеу.шуза1. соп/ аомп1оайз/сиі-б0о15/5.0.Һі 


Имеются версии для Міпаомѕ, Мас и іпих. Программа Му5ОГ. Аатіпіѕігаѓог обе- 
спечивает возможность простого и удобного просмотра, создания и редактирова- 
ния баз данных и таблиц. 


Также вам может пригодиться программа Му5 ОГ, Оцегу Вгомзег. Она позволяет вве- 
сти запрос и просмотреть результаты в интерфейсе программы (вместо консоли). 


Здесь Вводяился запросы. 


Ехесшіе + 50р 


об 25; Опед @ 1оса!о54 ма вок | 
ЗЕРЕСТ пате, боѕѕ іа РКОМ сіомл_ 4 | 


па 
а 29 
2 
3 $пи9ае$ 10 
Здесь Выводяился 4 Мг. НоБо з 
Резульилаилы. 5 С!агабене 10 
5 Ѕсоо?ег Е 
7 21рро Е] 
8 Вађе 5 
9 Воп20 5 
№ 10 Міѕтег Ѕ5піёћеѕ 10 


10 гож їегсћей. Ф сат | Ж Сапе м? ба [М и | М тах | 2 зеасн 


Ѕеіестед ѕсһета 'огед$ г. 


550 приложение ! 


Другие графические инструменты 


прочее 


Также существует немало других графических программ для работы с МуЅ0І. 
Выберите из них ту, которая лучше всего подходит лично вам. Ниже приведены 
лишь некоторые примеры, а остальное можно легко найти поиском в Интернете. 


Пользователям Мас стоит обратить внимание на СосоаМу5ОГ: 


Һер: //сосоамуза1 . зопгсеЕогде .пее/ 


ооо (МУЗОЕ 5.0.37) гоо@осаіпоѕ1/сћ8/оуѕ 


Ѕһом Сопѕоіе Сеаг Сопѕоіе 


Ѕһом Мапабіез РызН РлімПедеѕ 


Тәре Орегаіопз Сееате Тае Ѕутїах 


2 —\. | к 
__ Кноики для 


ви 9. Еи те иросмоилра 
Е у гуа силрукилуры 
8) мо ити С запроса, его 
ТаБеѕ Боу тоу 1а вылолнения 

-. Оауеу Е 

= С. у и изменения 
он вы 2 иладлицы. 
уса сте 1 

аи юһпоу А 

ви 2 

в) 98 
1-1 ООС 


Го айп 1 бане #1 


[96 6 гомз іп саше 
Се 


Если вам требуется сетевое решение, попробуйте использовать рһрМуАдтіп. 
Эта программа хорошо подходит для удаленного администрирования Му5ОГ, 
по Интернету. Для работы с МуЅОІ на локальном компьютере она менес 
удобна. Дополнительную информацию можно найти на странице: 


ЪЕЕр: / /мии . рьртуаат1п . пее/ 


Далее перечислены другие популярные графические инструменты. Некото- 
рые из них работают исключительно на платформе РС; чтобы узнать, подой- 
дутли они вам, лучше всего зайти на сайт и прочитать информацию о по- 


следней версии. 


М№Мауісаї предоставляет 30-дневный бесплатный пробный период: 


Һер: //мми .пау1са* . сот/ 


ЗОГуорв предлагает бесплатную версию Соштипиу ЕЧ1йоп: 


ВЕЕР: / /мми .меьуод . сот/еп/ 
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Зарезервированные слова и спеииальные символы 


2. ЗарезерВироВанные слоВа и специальные символы 


В языке $01. довольно много зарезервированных ключевых слов. Эти слова не рекомендуется ис- 
пользовать в качестве имен баз данных, таблиц и столбцов. Даже если вам очень хочется назвать 
новую таблицу «ѕеІесі», попробуйте найти более содержательное имя, в котором «ѕе]есі» не встре- 
чается. А если без зарезервированного ключевого слова никак не обойтись, постарайтесь исполь- 
зовать его с другими словами и символами подчеркивания, чтобы не путать РСУБД. На следующей 
странице приведен список ключевых слов, которые не рекомендуется использовать в именах. 


Ситуация усложняется тем, что в 501 имеются незарезервированные слова, которые могут ока- 
заться зарезервированными в будущих версиях 5091. Мы не будем перечислять их здесь; найдите их 
в справочнике по вашей конкретной РСУБД, который вы купите после знакомства с этой книгой. 


(пециальные символы 


Ниже перечислены многие специальные символы 501 с краткими описаниями. Как и ключевые 
слова, их не рекомендуется использовать в именах — исключение составляет только символ под- 
черкивания (_). В общем случае имя не должно содержать никаких символов, кроме букв и симво- 
лов подчеркивания. Имена из одних цифр тоже нежелательны, хотя и они иногда оказываются 
содержательными. 


* Возвращает все столбцы таблицы в команде ЗЕЪЕСТ. 


() Используются для группировки выражений, определения порядка выполнения математиче- 
ских операций и вызова функций, а также для ограничения подзапросов. 
: Завершает команды 501. 
Разделяет элементы списков (например, в команде ІМЅЕВЋТ или условии ІМ). 


Являюился сиеци - 


альными символа ~ 
Используется в ссылках на имена таблиц ив дробных числах. ми илолько с ШКЕ. 


Представляет один символ в условии 1ІКЕ. == . 


Представляет несколько символов в условии 11КЕ. 
Обозначает отрицание (МОТ); используется при сравнении в условиях НЕЋЕ. 


Строковые значения в 501 заключаются между двумя апострофами. 
Также для этой цели можно использовать кавычки, хотя лучше ограничиться апострофами. 
Используется для включения апострофов в текстовые столбцы таблиц. 


Кроме операции сложения, также используется для конкатенации (сцепления) строк. 


Краткая сводка математических операторов. 


Деление 


& | ^ ~ 


РА Не меньше РА Меньше либо равно 


В книге не рассматриваются. 
За информацией обращайтесь 
к документации своей РСУБД. 
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прочее 


ЭЗилоил список рекомендуется иросмаилриваиль 
каждый раз, когда 8 программе какому-либо объ- 
Зарезервированные слова (2 ёкилу присваиваеился имя из одного слова — убеди - 


ү илесь 6 илом, чило эило слово не зарезервировано. 


У АВЅОШЈТЕ АСТТОМ Ар АШМТМ АЕТЕВ АССВЕСАТЕ АТГТА$ А11, АГГОСАТЕ АГТЕВ АМО АМҮ АВЕ АВКАУ АЗ 
ЦИИ АЗС АЗЗЕВТТОМ АТ АОТНОВТРАТТОМ 


ВЕРОВЕ ВЕСТМ ВТМАВУ ВІТ ВІОВ ВООГЕАМ ВОТН ВВЕАОТН ВУ 


САТТ, САЅСАРЕ САЅСАРЕӘ САЗЕ САЗТ САТАГОС СНАВ СНАВАСТЕВ СНЕСК СІАЅ5 СІОВ СІОЅЕ СОШ.АТЕ 
СОБЦАТТОМ СОГОММ СОММТТ СОМРІЕТІОМ СОММЕСТ СОММЕСТТОМ СОМЗТВАТМТ СОМ5ТВАТМТ$ 
СОМ5ТВОСТОВ СОМТТМОЕ СОВВЕЗРОМОТМС СВЕАТЕ СВО$$ СОВЕ СОВВЕМТ СУВВЕМТ РАТЕ 

СОВНЕМТ РАТН СОВАЕМТ ВОГЕ СОВВЕМТ ТІМЕ СОВВЕМТ ТТМЕЗТАМР СОВВЕМТ ОЗЕВ СОК$ОВ СҮСІЕ 


ЮАТА РАТЕ РАУ РЕАТТОСАТЕ РЕС ОЕСТМАТ ПЕСІАВЕ ОРЕГАОГТ РЕЕЕВВАВЦЕ РЕГЕВКЕО РЕГЕТЕ РЕРТН 
рЕВЕЕ РЕЗС РЕЗСВТВЕ РЕЗСВТРТОВ РЕЗТВОУ РЕЗТВОСТОВ РЕТЕВМТМТ$ТТС РІСТІОМАВҮ ОТАСМОЗТТС$ 
ОТ5СОММЕСТ ОТ5ТТМСТ РОМАТМ ОООВІЕ ОВОР рүМАМІС 


ТОЕМТТТУ ТСМОВЕ ТММЕОТАТЕ ТМ ТМОТСАТОВ ІМІТІАІІ2Е ІМІТІАІ1Ү ТММЕВ ТМООТ ТМРОТ ІМЅЕВТ 
ІМТ ТМТЕСЕВ ІМТЕВЅЕСТ ТМТЕВУАТ ТМТО 15 ТЗОГАТТОМ ІТЕКАТЕ 


ЈОІМ 
Такара Вова 


ТАМСОАСЕ ГАКСЕ ТАЗТ ІАТЕКАІ ГЕАОТМС ІЕЕТ 1Е55 ІЕУЕІ ГТКЕ ІІМІТ ІОСАІ ІОСАІТІМЕ 
ТОСАЦТТМЕЗТАМР ГОСАТОВ 


ВИЖ МАР МАТСН МТМОТЕ МООРТЕТЕ$ МОРІҒҮ МОБОБЕ МОМТН 
ШИЙ МАМЕЗ МАТТОМАГ МАТОВАТ, МСНАВ МСТОВ МЕИ МЕХТ МО МОМЕ МОТ МОГ МОМЕВТС 
ФИ ОВЈЕСТ ОЕ ОБЕ Оо ОМ ОМГУ ОРЕМ ОРЕВАТТОМ ОРТТОМ ОВ ОВОЕВ ОВОТМАГТТУ ООТ ОПТЕВ ООТРОТ 


РАО РАВАМЕТЕВ РАКАМЕТЕВЅ РАРТІАІ, РАТН РОЗТЕТХ РВЕСТЗТОМ РВЕРТХ РВЕОВОЕВ РКЕРАВЕ 
РВЕЗЕВУЕ РКІМАВҮ РАТОВ РВІҮУІГЕСЕЅ РВОСЕРОВЕ РОВЬТС 


_ СНОН ЕЕРЕЕ НЕЕ ЕНЛИ Й 


ВЕАО ВЕАӘрѕЅ БВЕАІ, ВЕСОВЗТУЕ КЕЕ ВЕРЕВЕМСЕЗ ВЕРГЕВЕМСТМС ВЕГАТТУЕ ВЕЗТВТСТ ВЕЅ(ОЛТ ВЕТОВМ 
ВЕТОВМ$ ВЕУОКЕ ВТСНТ ВОГЕ ВОШГВАСК ВОГГОР ВОЧТТМЕ КОМ ВОИ5 


ЗАУЕРОТМТ ЅСНЕМА $СВОГТ ЅСОРЕ ЗЕАВСН ЗЕСОМР ЗЕСТТОМ ЗЕЦЕСТ ЗЕОЧЕМСЕ ЗЕ$ЗТОМ 
ЗЕ$ $ ТОМ_О5ЕВ ЅЕТ ЅЕТЅ 5Т2Е ЅМАГІІМТ ЅОМЕ ЅРАСЕ ЗРЕСТЕТС ЗРЕСТЕТСТУРЕ $01 ЗОЪЕХСЕРТТОМ 
ЗОГЗТАТЕ ЗОГМАВМТМС ЅТАРТ ЅТАТЕ ЗТАТЕМЕМТ ЗТАТТС ЗТВОСТОВЕ ЗУЗТЕМ О5ЕВ 


| ТАВІЕ ТЕМРОВАНУ ТЕВМТМАТЕ ТНАМ ТНЕМ ТІМЕ ТТМЕЗТАМР ТІМЕ20МЕ НООЕ ТТМЕРОМЕ МТМОТЕ ТО 
ТВАТГТМС ТКАМЅАСТІОМ ТВАМЗГАТТОМ ТВЕАТ ТАТССЕВ ТВОЕ 


ОИ ОММОЕВ ОМІОМ ОМТОЧЕ ОМКМОММ ОММЕЗТ ОРРАТЕ ОЗАСЕ ОЅЕВ 05ІМС 


ПИЙ УАГОЕ УАТЈЕЅ УАВСНАВ УАКІАВІЕ УАВУТМС УТЕМ 
ШИЙ УНЕМ ИНЕМЕУЕВ ИНЕВЕ ИТТН МІТНООТ МОВК ИВТТЕ 
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АМҮ, АШ и ЗОМЕ 


3 АЦ АМУ Ц $0МЕ гезіаџгапї гаёіпоѕ 

Б ! 

тате | майнд | 
ПО ОСИ 
АїЫ5 ‘п’ Моге 


Три ключевых слова А11, АМҮ и 5ОМЕ очень полезны при 
работе с подзапросами. Они работают с операторами сравне- 
ния и наборами результатов. Прежде чем переходить к их 
рассмотрению, вспомните оператор ІМ из главы 9. 


ЅЕГЕСТ папе, габіпд ЕВОМ гезёаџгапі габіпадѕ 
ИНЕРКЕ гаііпд ІМ 
(ЅЕГЕСТ гаіпд ЕВОМ гезфазгапЕ гаііпдѕ Подзамрос возврашаеил все 
МНЕВЕ гаёіпд > 3 АМЮр гаёіпд < 9); 29° оценки в диапазоне ом 5 до 9 — 
8 данном случае 7 и 5. 
Этот запрос возвращает все названия ресторанов с такими 
же оценками, как у результата подзапроса в круглых скобках. 
Результат состоит из двух записей, Тйе Ѕћаск и В165 п’ Моге. 


Ключевое слово АШ. 


А теперь рассмотрим следующий запрос: 


ЅЕТЕСТ пате, га®1пд ЕВОМ гезбаџгапі гаііпдзѕ > АЦ, находит вее 
МНЕВЕ гаііпд > АШ, 
(ЅЕГЕСТ габіпс ҒРКОМ гезіацгапі гаііпоѕ значения, большие 


МНЕВЕ гаііпс > 3 АМО гаііпд < 9); 
. максимального значе- 
На этот раз мы хотим получить все рестораны с оценкой, 
превышающей все оценки в наборе (это ресторан Аййиг”). НИЯ В наборе 


Пример запроса с оператором <: 


ЅЕЦЕСТ пате, габіпд ЕВОМ гезфаигапе габіпдѕ 


МНЕВЕ габіпд < АШ, 
(ЅЕТЕСТ гаііпд ЕВОМ гезфапгапЕ гаііпдѕ ИНЕБКЕ < АЦ, находит вее 


гасіпа > 3 АМО гаііпа < 9); значения. меньшие 
И 


САІШ, также можно использовать операторы >= и <=. Сле- 


дующий запрос вернет записи Тће ЅћасЕ и Атћиг?. В резуль- минимального значе- 
тат включаются записи с оценкой, большей либо равной 
наивысшей оценке в наборе, которая равна 7: НИЯ В наборе. 
ЗЕЦЕСТ пате, габіпс ЕВОМ гезёацгапё гаііпдзѕ 
МНЕВЕ габіпд >= АШ, = В резульилаил вВключаюился записи 
(ЗЕБЕСТ га&1п9 ЕВОМ гезфаигапЕ габіпоз с оценкой, большей либо равной 
ИНЕВЕ гаіпд > 3 АМО габіпд < 9); наивысшей оценке в наборе. 
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прочее 


Ключевое слово АМҮ 


Условие с АМҮ истинно, если хотя бы одна запись в наборе удо- 

влетворяет условию. Рассмотрим следующий пример. > АМУ находит все 
ЗЕТЕСТ пате, гаііпд ЕВОМ геѕёацгапё габіпдѕ значения бо льшие 
ИНЕРВЕ га®1пд > АМҮ " 
(ЗЕЪЕСТ гаііпд ЕВОМ геѕёаџгапіё гаііпдѕ МИНЕКЕ минимального значе - 


габіпд > 3 АМО габіпд < 9); 


ния в наборе. 


Он означает следующее: «Выбрать все записи, у которых оцен- 
ка больше, чем хотя бы одно из значений набора (5, 7)». Так 
как оценка Тће Ѕ$һаск равна 7, что больше 5, запись включается 


в результат. Также возвращается запись Ат#ит с оценкой 9. < АМУ находит вее 


значения, меньшие 
максимального значе- 


ния в наборе. 
Ключевое слово $ОМЕ 


СОМЕ означает то же, что АМҮ в стандартном синтаксисе $ОГ. 
Чтобы узнать, работает ли это ключевое слово в вашей РСУБД, 
обращайтесь к документации. 
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4. Подробнее о типах данных 


Основные типы данных вам уже известны, но некоторые подробности помогут еще точнее 
подобрать нужный тип для ваших столбцов. Давайте рассмотрим несколько новых типов, 
а также поближе познакомимся с теми типами, которые уже использовались ранее. 


ВООТЕАМ 


В столбце этого типа может храниться значение «(гие», «Ёа[ѕе», или же он может остаться 
равным №011. Тип очень удобен для хранения логических признаков «истина/ложь». Во 
внутреннем представлении РСУБД сохраняет 1 для истинных значений или 0 для ложных. 
При вставке также можно указывать 1 вместо «ігие« или 0 вместо «Ѓа[ѕе». 


ІМТ 


Тип ІМТ неоднократно использовался в книге. В столбцах этого типа могут храниться 
значения в диапазоне от 0 до 4 294 967 295 в том случае, если столбец должен принимать 
только положительные значения. 


Если значения столбца могут быть как положительными, так и отрицательными, следует 
определить столбец типа ІМТ со знаком. Значения таких столбцов лежат в диапазоне от 
—2 147 483 648 до 2 147 483 647. Чтобы сообщить РСУБД, что в столбце должны храниться 
числа ІМТ со знаком, используйте следующий синтаксис при создании столбца: 


ІМТ ($1СМЕр) 


Другиие разновидности ІМТ 


Тип ІМТ вам уже известен, но два типа ЗМАЬЬТМТ и ВІСІМТ помогают немного оптимизиро- 
вать хранение информации. Они определяют наибольшее число, которое может храниться 
в столбце. 


Диапазоны значений этих типов зависят от конкретной СУБД. В МуЅ0!І они выглядят так: 


ЅМАІІІМТ от –32768 до 32767 от О до 65535 


вІСІМТ от —9223372036854775808 ото 
до 9223372036854775807 | до18446744073709551615 
Кроме того, в МуЅО[. дополнительно определены следующие целочисленные типы: 


е сай со знаком без знака 
ТІМҮІМТ от -128 до 127 от 0 до 255 


МЕРІОМІМТ от 8388608 до 8388607 от О до 16777215 
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Типы ОАТЕ и ИМЕ 


Ниже приведена сводка стандартных форматов типов даты и времени в Му5ОГ. 


рАТЕ ҮҮҮҮ-ММ-рр 

РАТЕТТМЕ ҮҮҮҮ-ММ-0р НН:ММ:55 
ТІМЕЅТАМР УУУУММООННММ5$ 

ТІМЕ НН:ММ:$5 


зоше_Чафез 


1925-01-01 02:05:00 


2007-08-25 22:10:00 


При выборке из столбца, содержащего дату и/или время, можно изменить фор- 
мат возвращаемых данных. Функции форматирования даты / времени зависят 
от конкретной РСУБДД. Рассмотрим пример использования функции Му ОГ, 


ВАТЕ НЕ ОВМА О: Формаилные силроки должны 
Допустим, у вас есть столбец а_даке: б, быиль заключены 6 апосилрофы. 


ЗЕТЕСТ ОАТЕ ЕОБМАТ (а дае, '%М %У') ЕВОМ зоте Паѓеѕ; 


Обозначения %М и %У описывают нужный формат даты. Результат должен вы- 
глядеть примерно так: 


Аџдиѕї 2007 


Јапиагу 1925 


Количество параметров форматирования огромно; рассмотреть их здесь нам 
не удастся. Просто запомните, что параметры форматирования позволяют 
получить значения столбцов даты/времени в нужном формате, одновременно 
отсекая все лишнее. 
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5. Временные таблицы 


В этой книге мы создали много разных таблиц. Каждый раз при создании таблицы 
РСУБД сохраняет описание ее структуры. При вставке данных РСУБД сохраняет эти 
данные. Если завершить сеанс 501. в окне терминала или в графической программе, 
таблица и хранящиеся в ней данные никуда не пропадут. И таблицы, и данные остают- 
ся в базе до тех пор, пока вы не удалите их. 


ЗОГ. также поддерживает другую разновидность таблиц — так называемые вфеменные 
таблицы. Временная таблица существует от ее создания до момента удаления или до 
завершения полъзовательского сеанса. Под сеансом понимается промежуток времени от 
подключения к РСУБД с данными учетной записи до выхода или завершения графи- 
ческой программы. Временные таблицы также могут удаляться явно командой ОВОР. 


Для чего может понадобиться Временная таблица: 


• Во временной таблице можно сохранить промежуточные результаты — например, 
результат выполнения некоторой математической операции со столбцом, кото- 
рый вам понадобится только во время текущего сеанса. 


• Вам потребуется сохранить содержимое таблицы на заданный момент времени. 


• Помните, как мы преобразовали базу данных Грега из одной таблицы в группу 
связанных таблиц? Временные таблицы упрощают реструктуризацию данных, 
и вы можете быть уверены в том, что они исчезнут после завершения сеанса. 


• При использовании 501. в приложениях, написанных на языке программирования, 
вы можете создать временные таблицы на время сбора данных, а затем сохранить 
результаты в долгосрочной таблице. 


Создание Временной таблицы Синтаксис 


Синтаксис создания временных таблиц в Му5ОГ. прост — создания 


достаточно добавить ключевое слово ТЕМРОВАБУ: временных 
ульхое | таблиц 
Я ТЕМРОКАВУ ТАВІЕ шу_фептр_фаь1е остророжНы; зависит 
аске за Інт, “ча ТЕМРОРАВУ — от РСУБД. 
зоте дафа УАВСНАВ (50) единсилвенное изме - : За информацией об этой 
) нение в команде. : возможности обращайтесь 
: к документации РСУБД. 


Сокращенный синтаксис о ле 1 


Временные таблицы также можно создавать по результатам запросов: 


СВЕАТЕ ТЕМРОВАВҮ ТАВІЕ ту +етр +аЪ1е АЗ 
ЗЕТЕСТ * ЕВОМ му регтапепе +аБ]е; 
=_ После АЅ можеил следоваиль 
произвольный запрос. 
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6. Преобразование типа 


Иногда в столбце хранятся данные одного типа, а вам необходимо ин- 
терпретировать их как данные другого типа. В $ОГ, преобразование типа 
осуществляется функцией САСТ(); 


Синтаксис: 
САЅТ (столбец, ТИП) 


Допустимые значения параметра ТИП: 
СНАР () 
РАТЕ 
рАТЕТІМЕ 
РЕСТМАГ 
$ТСМЕР [ТМТЕСЕВ] 
ТІМЕ 
ОМЅІСМЕЮ [ІМТЕСЕК] 


Когда может потребоваться функция СА$Т()? 
Преобразование строки к типу РАТЕ: Силрока ‘2005-01-01? 


лреоб 
ЅЕІЕСТ САЅТ('2005-01-01' АЗ РАТЕ); < р" к илииу 


Преобразование целого числа в дробное: 
реоор Б В Целое число 2 превра - 


ЗЕЪЕСТ САЅТ(2 АЅ ЮЕСІМАІ); <——^ /426//С7 6 дробное 2.00. 


Функция САЗТ () применяется и в других ситуацих: в списках значений 
ТМУЕВТ, в списках столбцов ЗЕТЕСТ ит. д. 


Функция САЗТ() не может использоваться 
для преобразования: 


• Дробных чисел в целые; 
+ ТІМЕ, РАТЕ, РАТЕТТМЕ, СНАК в ОЕСТМАГ и ІМТЕСЕК. 
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получение текущей информации 


7. Имя пользователя и текущее Время 


Иногда для одного пользователя в РСУБД создаются несколько учетных запи- 
сей с разными разрешениями и ролями. Чтобы узнать, какая учетная запись 
используется в настоящий момент, введите следующую команду: 


ЅЕГЕСТ СУВВЕМКТ ОЗЕБВ; 


В выходных данных команды также указывается имя хоста. Если РСУБД рабо- 
тает на одном компьютере с пользователем, а пользователь работает с учет- 
ной записью 700 команда выдаст следующий результат: 


гоої@1оса1ћозі 


Вы можете узнать текущую дату и время с помощью следующих команд: 
Ее Еай У/паому Нар 

ЅЕІЕСТ СОВВЕМТ РАТЕ; 
- 
СОВВЕМТ РАТЕ | 
бх фк + 
2011-06-07 | 
+ 


гом іп зеё (0.00 5ес) 


> ЗЕТЕСТ СОВВЕМТ ТІМЕ; 
+ + 
| СОВВЕМТ ТІМЕ | 


11:26:48 


1 гом іп ѕзеё (0.00 зес) 


Ре Еди \У/Лпдом Неір 

ЗЕГЕСТ СОВВЕМТ ОЗЕВ; 
+ + 

| СОВВЕМТ ОЅЕК 
авы 

| гооЁ@1оса1Һоѕі 

+ - - - - + 


1 гом іп зе (0.00 зес) 
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8. Полезные числовые функции 


Ниже перечислены функции для работы с числовыми 
типами данных. Некоторые из них мы уже видели. 


Числовая Назначение 


функция 
Возвращает модуль (абсолютную величину) х 
зЕІЕСТ АВ (-23); 


АСО$ (х) 


Е ЗЕБЕСТ АСОЗ (0); 1.5707963267949 
Е а ен 

[зЕгст атАн(-22; _  [0.78539816339745 

мое значение имеет тип ВІСІМТ 
ВИ 
е 
ВЕЗИ 60 ата 


ЗЕШЕСТ СОТ (12); -1.5726734063977 


Е Возвращает результат возведения числа е в степень х 


ЅЕ1ЕСТ ЕХР(-2); 0.13533528323661 
Возвращает наибольшее целое, меньшее либо равное х 
ЅЕГЕСТ ЕТООВ (1.32); 


ҒОВМАТ (х,у) Преобразует х в отформатированную текстовую строку с округлением 
до у цифр в дробной части 


ЗЕГЕСТ ЕОБМАТ (3452100.50,2); |3,452,100.50 


Возвращает натуральный логарифм х 
0.69314718055995 


ТОС (х) апа Возвращает натуральный логарифм х, или, при использовании двух пара- 
106 (х,у) метров, возвращает логарифм х по основанию у 


ЅЕІЕСТ 106 (2); 0.69314718055995 


| 
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другие числовые функции 


8. Полезные числовые функции (продолжение) 


Описание 


Числовая 
функция 


МОр (х,у) 


Возвращает остаток от деления х на у 


ЅЕГЕСТ МОр (249,10); 


Возвращает число "пи" 
ЅЕ1ЕСТ РІ(); 3.141593 


Возвращает результат возведения х в степень у 


РОЙЕК (х,у) 


ВАОТАМ$ (х) Возвращает результат преобразования х из градусов в радианы 
ЅЕТЕСТ КАРІАМ№Ѕ (45); 0.78539816339745 
Возвращает случайное вещественное число 

ЅЕТЕСТ РАМ (); 0.84655920681223 
Возвращает значение х, округленное до ближайшего целого 
ЅЕГЕСТ ВОЈ” (1.34); 
ЅЕ1ЕСТ КООМ” (1.34); 
Возвращает значение х, округленное до у цифр в дробной части 
ЅЕГТЕСТ ВООМРр (1.465, 1); 1.5 

ЗЕЪЕСТ КООМРО (1.465, 0); 

ЅЕТЕСТ КООМ” (28.367, -1); 


Возвращает 1, если число х положительно, 0 — если оно равно 0, или -1 для 
отрицательного х 
ЅЕ1ЕСТ $ТСМ(-23); 


Возвращает синус х 


1 


КОЧКОР (х,у) 


= 


1.2246063538224е-16 


Возвращает квадратный корень из х 
ЗЕЪЕСТ 5ОВТ (100); 
Возвращает тангенс х 


ЅЕГЕСТ ТАМ (РТ ()); -1.2246063538224е-16 
Возвращает число х, усеченное до у цифр в дробной части 
ОИ ЕЕ ТОНЕР О [еэ 


- 
о 
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9. ИндексироВание для ускорения операций 


Вы уже знаете, что такое индексирование по первичному и внешнему 
ключу. Такие индексы отлично подходят для логического связывания 
таблиц и обеспечения целостности данных. Однако индексы также 
можно строить для отдельных столбцов, чтобы ускорить обработку 
запросов. 


Если условие ИНЕКЕ применяется к неиндексировапному столбцу, 
РСУБД начинает с первого значения этого столбца и последовательно 
проверяет все записи, одну за одной. Для большой таблицы (скажем, 

4 миллиона записей) перебор займет достаточно продолжительное 
время. 


При построении индекса для столбца РСУБД сохраняет дополнитель- 
ную информацию о столбце, которая значительно ускоряет поиск. 
Дополнительная информация, организованная особым образом, хра- 
нится в специальной служебной таблице. За экономию времени при- 
ходится расплачиваться дополнительными затратами пространства. 
Следовательно, индексировать следует только те столбцы, по которым 
часто проводится поиск. 


Общая схема выглядит так. 


Определите, для каких столбцов вашей базы индексировапие будет 
наиболее эффективным. Например, представьте, что в огромной та- 
блице а11 сопёасіѕ часто выполняется поиск по столбцам 1аѕї _ 
папе и Ёігѕ пате. Выполнение запросов стало занимать слишком 
много времени, и вы решаете, что операции пеобходимо ускорить. 


В МУу5ОГ для построения индекса с именем а1] сопёасіѕ патез 
используется следующая команда: 


АГТЕВ ТАВІЕ пу сопбасіѕ 
АБР ТМОЕХ а11 сопіасїѕ патеѕ (1аѕ+ пате, Ғігѕб папе); 


Индекс также можно построить командами следующего вида: 


СВЕАТЕ ТМОЕХ а11 сопбасєѕ патеѕ 
ОМ а11 сопеас®$ (1азё пате, ЁҒігѕї пате); 


Построение индекса а11 сопёасіёѕ патеѕ имеет одно интересное 
последствие: при выполнении запроса к исходной таблице (напри- 
мер, ЗЕЦЕСТ * РВОМ а11 сопёасіѕ) записи будут отсортированы 
по значению Ііаѕе пате со вторичной сортировкой по ігѕё пате 
без указания порядка в команде. 
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РНР МуЅаЕ с высоты 16.000 метров 


10. РНР/МУЗОЕ за 2 минуты 


Напоследок давайте очень кратко рассмотрим возможности взаимодей- 
ствия с МуЅОІ из РНР для выборки данных по Интернету. Этот крошечный 
раздел дает лишь начальное представление об этой возможности, и вам 
определенно стоит подробнее изучить эту тему. 


Предполагается, что читатель уже немного разбирается в РНР а также 
достаточно уверенно пишет запросы $01. Следующий фрагмент кода под- 
ключается к базе данных с именем дгедѕ 1іѕі и выполняет выборку имен 
и фамилий из таблицы ту сопѓіасіз. Код РНР сохраняет все данные, загру- 
женные из базы, в массиве. Последняя часть кода выводит список имен 

и фамилий на веб-странице. 


<?рһр 
$сопп = муза! соппесі ("1оса1һозі", "дгед","дг3д2рАз"); 
іҒ (!$сопп) 

{ 


аје ('ріа поё соппесі: ' . шуза1_ еггог()); 
шүѕа1 ѕе1есі ар ("љу аь", $сопп); 
$гези1 = туѕд1 аџегу("ЅЕІЕСТ Ғігзі паше, 1азЕ пате ЕВОМ му сопбасізѕ"); 
мһі1е ($гои = муза Ғеісһ аггау ($геѕџі+)) 
{ 


есһо $гом['Е1гзЕ паше'] . " " . $гои['1аѕі пате']; 


есһо "<ЫЬг />"; 


шуза1_с1озе ($сопп); 


?> 


Файл сохраняется под именем дгедзпатез .рЬр на веб-сервере. 
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Подробнее о Каждой строке 


<?рҺр 
Первая строка сообщает веб-серверу о том, что дальше следует код РНР. 
$сопп = шуза1 соппесі ("1оса1ћозіё", "гед", "9г392рАѕ"); 


Чтобы подключиться к базе данных дгедз 1ізі, необходимо сообщить веб-серверу ее местонахожде- 
ние, имя пользователя и пароль. По этим данным создается строка подключения, которой присваива- 
ется имя $сопп. Функция РНР туза1 соппесї () получает эту информацию и пытается использовать 
ее для подключения к РСУБД. 


ЗЕ (! $сопп) 
{ 


аіе('ріа поё соппесё: ' . муза1 еггог()); 


} 


Если подключение не состоялось, РНР отправляет сообщение с описанием причины, а обработка 
кода РНР на этом прекращается. 


шузч1 зе1есе ар ("шу 46", $сопп); 


Подключение к РСУБД прошло успешно. Теперь мы должны указать РНР, какая база данных нас инте- 
ресует. Для выбора базы данных дгедѕ 115 используется команда 05Е: 


$геѕо1ї = щуза1 ааеку("ЗЕЪЕСТ Ғігзё пате, 1аз пате ЕВОМ шу сопіасіз"); 


База данных выбрана, подключение создано, но еще нет запроса для выполнения. Мы создаем такой 
запрос и отправляем его РСУБД функцией туза1 аџегу (). Все возвращаемые записи сохраняются 
в массиве $ геѕџ1ёЁ. 


мһі1е ($гом = шуза1 Ғеісһ аггау ($гезио1+)) 
{ 


Теперь синтаксис РНР используется для вывода содержимого $ге5и1 на веб-странице. Цикл $1 11е 
перебирает записи, пока не будет достигнут конец данных. 


есһо $гом['Е1г5е паше'] 1": ет $гоч['1аз пате']; 
есћо “<Ьх />”; 
} 


Две команды РНР есһо выводят на веб-странице поля Ё1г5® пате и 1аѕї пате каждой записи. Вы- 
водимые строки разделяются тегами НТМІ, <рг>. 


1озе ($сопп); 


После того как все данные будут выведены, подключение к РСУБД закрывается (по аналогии с завер- 
шением сеанса работы за терминалом). 


?> 


Сценарий РНР на этом завершен. 
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|| РУЛежение |І: Установка М), 


су Р? + 
+ Попробуйте сами 


МЕН _ 
МОК 


Кто же знал, что там внизу 
целая РСУБД? Может, 
я вообще не вернусь. 


Ваши новые знания принесут пользу только в том 
случае, если вы сможете применить их на практике. 


В этом приложении содержатся инструкции по установке РСУБД Муѕат!. 


установка Муз О! 


За дело! 


Было бы странно прочитать книгу о языке 501, не имея возможности 
поэкспериментировать с ним. В этом разделе приведено краткое опи- 
сание процесса установки МУЗОГ, для систем УЛп4омз и Мас ОЅ Х. 


ПРИМЕЧАНИЕ. Материал раздела относится к Міпаомѕ 2000, 
ХР и Міпаомѕ Зегуег 2003, а также другим 32-разрядным 

операционным системам семейства М/іпаомѕ. На платформе 
Мас он относится к Мас ОЗ Х 10.3.х и более поздних версий. 


Итак, в этом разделе приводится пошаговое описание процесса за- 
грузки и установки Му5ОГ.. Бесплатная версия сервера РСУБД МубОГ, 
называется МУЗОТ, Соттипиу Ѕегуег. 


Инструкции и устранение проблем 


Далее приводится список основных действий по установке Му5ОГ. для 
МЛпаомз и Мас ОЅ Х. Этот список не заменяет подробные инструкции 
на сайте Му5ОГ, и мы настоятельно рекомендуем посетить сайт 

и ознакомиться с инструкциями! Подробные инструкции, а также 
руководство по устранению проблем в ходе установки приводятся по 
адресу: В 
„а Нужна версия 5.0 
и Выше. 


БЕЕРр: //аеу.шуза1 . соп/аос/геҒтап/5. 0/еп/міпдоиѕз-іпзёа11аёіоп.Һіт1 


Вам также пригодится программа МуЅО1 Оцегу Вгомзег, упоминав- 
шаяся на с. 550-551. Она позволяет вводить запросы и просматривать 
результаты в интерфейсе приложения (вместо окна консоли). 
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установка Му$ ОЕ 


Установка Муз ОЕ В системе Міпаомс 


[1] Откройте страницу: 
ЬЕЕр: / /4еу.шуза1 .сот/4очп1оаЯз/шуза1/5.0.В 11 


и щелкните на кнопке Оомп]оа4 в разделе Му5ОГ, Соттипиу Ѕегуег. 


Возможно, список 


И ИРидеился ирокру- 
38 Ф мула муа потожья м4 - & "№ илииль вниз. 


фота Сотмииу Созтотегь Мон В Еме АБОМ Ном то 9% ) 


МУЗОЕ 5.0 Оомпіоайѕ 


у к Му5@І. 
| ==" | Соттипйу 
Ў р | Шу сет теФос с бары ту оуздеета що о саде ача 
Вам нужно | 88 ЕЕ егег 
версия зо ПЕЕ 
и Выше. т, то а ии 


Ө Выберите ссылку Міпӣоуѕ. 


- 
> ое же ое ни а озова 


3% А1 МУбО АВ: Му 52 Ромтіоаів 


Саса засаа сепа та тае МУЗОН 5.0 Соли Зегеег - Сепегайу АувйаЫе (97 в Міпаом5 
Ерин, н ү/іпаомѕ хбА 


Еліирлег Зегвг мй 2130 00 атанабіе іп те зипеаоетя © 
М (зочмсе зпа пагу) Сотнтилйу 30498. 50 чие е іаіеѕі ( р («| ) 
Сомтіоадз бесіоп. ће 5110$ из оп 86 расе тах = Шпих поп КРМ аска 25 

орегайпо зузце из эге ап мій гета сопмещемву 


< То балдак палев аге посолупепдев о 

а Те Мах уегеюп іосіисез адайюта! 

езе е ќигеѕ Һау тайной па 

Мах уегвіоп 2150, юс тоз р 

перата 

= Ме Онро Брала мне 5) 
ташдеа аеозоспа са 


дат Фа МО. 5201) 
бео з0000 01 Р о 
Моќе: 1 р 


боме 
мӣ 


> Иена 
> беда 04 
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установка Му$01 в системе Ито: 5 


Загрузка установочного пакета 


570 


В разделе Міпӣомѕ аомп1оа4ѕ мы рекомендуем выбрать пункт 
Міпаомѕ 7ТР/Зееар.ЕХЕ, потому что в него включена программа, силь- 
но упрощающая процесс установки. Щелкните на ссылке РісК а Міггог. 


. ребе Я 
С: [едой бонбона йна Е 


за Ф | му аву ло ронена 


Мнзолма слмтиоа(8 (0) 


молие Е: 

Флпбомѕ 20/9еіир ЕХЕ (х86), 

Уо иютзїанег (ипар м С \} 

МЛпдозме х64 домтіоаав (рігїотт по!е3) 
\Ммпаоме Еѕѕеліізіѕ (АМОСА / те 

ЕМЕАТ) 


умодожѕ 21Р/5еќир ЕХЕ (АМО64 / уме! 
ЕМ64Т) 


МИЛОМ {айе (АМОЄ4 / пе! ЕМбАТ 


М05. 126012966022сбв4902е753476с(а205 | 5 
50.45 509м 


= Божпіоай | Рєк.а лётог 
гаіаге 
Оомћоаї ГЕК а дӯтог 
с40ра577е2есь965  %сайве97ъ6бетавь | бутаішге 


5045 2804 Оожтюад і БСК а тяге 
М5. =605948<20с:55670409006679#154СЪ 
5045 517м Осчтюад | РЕК а итог 


67963545346540251763395ас4858е72 | Здание 


5045 619м Роже | РКК а итог 


Проследииле за 
илем, чилобы был 
выбран Варианил 
СЕЖЕ. 


> 208 паб26—3%а02121а5747вср дете? ба | Змтзіое 


Цпих (поп ЯРМ раскадез) бомпіоайз (ріаїогго поез) 
Отоф8ё. дих-2 2, "=1апдага" в ас) 5045 755м Оочтоаа | РК а пітог 
В 3с5219515515с76395116 308514351 | Забааие 
Цаих (х6) 5045 604м Оомпюао 1 Рек атату 
ерсбь4аё5а6 21 14646а170220148с4 : олш 


аз ЦАМОВа ге ЕМм64т) 5645 632М Оомат ( Рик а пиги 
05 дозтовтьаа еба 9966112175284 | арии 
отих (А64. Вед Най АЗ 2 1. Зав) 5045 1322М Бозтюач | РҳК а ттун у 
> 749091422751с17е1140647а5528с714 | Ѕірлашге > | 
1 
| © тете | Ридескед Моде От, кию > | 
ие =: Ы ве 


ь 
Открывается список серверов, с которых можно загрузить копию 
установочного пакета; выберите сервер, расположенный ближе к вам. 


Когда загрузка файла будет завершена, откройте его двойным щелч- 
ком. Запускается мастер установки (Ѕеѓир Міғага), который и будет 
руководить процессом установки. Щелкните на кнопке Меже. 


№ МУЗОЕ Зегиег 5.0 - бешр Мигатй Е) 


Меісоте о Ње Ѕеішр МИгага бог МуЅ0. | , 
Ѕегчет 5.0 


Тһе бер Малага м@ авот уси іо тобу, гераі, ог гетюуе 
МУЗСХ Ѕегуег 5.0. То сопбпие, бск М№ехї. 


Двойной щелчок на 
файле оилкрываеил диа - 
логовое окно масилера 
усилановки. Шелкнииле 
на кноике Мехф. 


Сах) ека] | 


приложение 1 


установка Му$ ОЕ 


Выберите папку для установки 


16 Вам будет предложено выбрать один из трех вариантов установки: стан- 
дартную (Туріса1), полную (Сотріеѓе) или пользовательскую (Сиѕ‹от). 
В контексте нашей книги следует выбрать вариант Туріса!. 


Вы можете выбрать папку, в которую будет установлена РСУБД Му5ОГ. 
на вашем компьютере, но мы рекомендуем оставить предложенный по 
умолчанию вариант: 


Сс: \Ргодгат Еі1ез\Муѕо\МуѕЅ01 Ѕегуег 5.0 


Щелкните на кнопке Мех. 


ГВ Мусо сечие 50 - бемр Мисал 


| егу Со Ілзќай ће Ртодгат 
| Те магад і гвабу 10 Бег тіла 
} 
| ь 


ТЕ уси малі їо геем ог спагде апу оРуслх из (афабоп 52 Ніс, ФСК Васк. 
Безёпавоп Ғоідег: 


С:годгат Раез\Му5 С АМУЗСХ. Ѕегуег 5.0\ 


! Степ 5е Нло: 


Щелкните на КнопКе «Ісаї» — и Вее! 


© Открывается диалоговое окно «Кеаду (о па», в котором указа- 
на выбранная для установки папка. Если папка выбрана правиль- 
но, щелкните на кнопке Та$(ай. В противном случае щелкните на 
кнопке ВаскК, выберите другую папку и вернитесь к этому окну. 


Нажмите тз$аЦ. 
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Установка Му ОЕ В Мас 0$ Х 


Если на вашем компьютере установлена система Мас ОЅ Х 
Зегуег, то МуЅОІ. в ней уже присутствует. 


Прежде чем переходить к установке, проверьте, не установ- 
лена ли версия МуЗОГ. в вашей системе (Арр1ісабіопз/ 
Ѕегуег/МуѕоїІ Мападег. 


© Откройте страницу: 
ЪЕЕр: //аеу.туза1.сом/4омт1оаЯз /туза1/5.0.В 1 


и щелкните на кнопке Ромпюа4 в разделе МуЗОГ. Соттипиу 
бегуег. 


Возможно, список 
придеился прокрУу- 
илииль Вниз. 


Рълпоегв & оон» Соима у Созтотеға Чем & Еммј АБОМ һү МУЗОС? Ном 0 Виу 


Му5СЕ 5.0 Оомпіоадѕ 


и ната ве сооапианага ююкома 00 нмана мей непроста 
ое ов тя. 


пема. 
| 


| у оме тефюа о! моник тту пума шо ю баа во во | 
сотогуаене иоонаочма вп сори МУБОА. | 


Му5оЕ Соттипіќу 
Сеуле тенките мно мат ке а Зегуег 


му сы» м .,.,).)о—. 
ме зисту злы һы оста ^^ Оомпіоаа » 


САА тонів 


Сото 
астен 


амач 


| МУЗОЁ Соттипћу 


Ѕегмег 
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установка Му5$ Е 


Выберите в списке строку Мае ОЅ Х (расКаве огта{). 


Возможно, список 


и 
рт МУЗОЕ 5.0 Соттипіту Зегуег - СепегаЛу АчанаЫе (СА) Вевазе р ридеился лрокру - 
О чре ан асоии илииль Вниз! 


Зиһаснье Маж п Емегразе Загуег 1 зізо е аувіаре п а сиотадоепі Солитилйу Зегиег геіевта, беге мї ре воцгсе-опіу геівавав іл Бомевеп К! 
(зомсе апа Млағу) Согимиму БЕ. 50 же те (а1е: риризгуеа согптшпну $0игсез мій аһжауз бе аузда Зе тот ће боце 
Осттіоаає Засфол. ће Ылатіек Ива оп из рада тау ба голт в ргеміоие гаіевхе. ит злу саза, Кл} палез юг ай ошг зирропай: 
орегању зузіета вте апа мін төглаіс сотуеліепу вуаҳабіе кот іх раде 


> Т Зіапаага олала: #08 тосопуталае Юг тюз ина 


< Тһе Мах мегіол снјеє айаніола! еашгез таг гае по Бееп ехђацефееу №5) ь 
С ЗИ еа = Мас 05 Х (браскаае їогтаћ і 


= Тһе Оер Блапея пауе беел сопурйеб и? ахга бериў ка аана 
асьюед дериооим сое тау гаоисе оепоттагма 


уеже те МУЗСА 20 Ца 01 Срелоея 
ме падове бы уе шы ла МО састу 


мед (5 ссоре се юр — 


Выберите пакет, соответствующий вашей версии Мас ОЅ Х. 
Щелкните на ссылке Ріск а Міггог. 


Открывается список серверов, с которых можно загрузить копию устано- 
вочного пакета; выберите сервер, расположенный ближе к вам. 


Когда загрузка файла будет завершена, откройте его двойным щелчком. После уста- 
новки МуЅ0[ откройте электронную документацию и посмотрите, как работать 
с данными в программе Оцегу Вгомѕег, упоминавшейся на с. 550-551. 


Но если вы торопитесь, ниже описан быстрый способ работы с программой в тер- 
минальном режиме. 


Откройте окно терминала на Мас и введите следующие команды: 
зВе11> са /изг/1оса1/туза1 
зћһе11> зи4о ./Ь1п/туза1А зағе 

(Введите пароль, если потребуется.) 

(Нажмите Сопио]1-.) 
зће11> ЬЫ 


(Нажмите Сопего|- или введите ех1 для выхода из терминала.) 
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[|Ролежене Је (Съисок инстрруМентроВ 


№ 
Полный инструментарий 901 ». 
Я 


И нас може! 


Поилрясающе - вы изучили всех 
нас! 


В этом приложении перечислены все инструменты 
сте № упоминавшиеся в книге. Не жалейте времени, просмот- 


рите весь список и возрадуйтесь — ведь вы изучили их все! 


знаки-С 


Знаки 


= <> <> <= >Е 
В Вашем распоряжении целый набор опера- 
илоров сравнения. 


Глава 2 


А 


АІТЕК с СНАМСЕ 

Изменение имени и липа данных сущесил- 
вВующего силолдид. 

Глава 5 


АІТЕК с МООРУ 
Изменение илолько илипа данных сущесилву - 
ющего силолбца. 


Глава 5 


АІТЕК с АБО 
Добавление силолдиа в иладлииц в заданном 
порядке. 


Глава 5 


АІТЕК с ОКОР 
Удаление силолбца из илаблицы. 


Глава 5 


АІТЕК ТАВІЕ 

Изменение имени илаблицы и всей ее 
силрукилуры дез поилери данных. 
Глава 5 
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АМО и ОК 

АМР и ОВ объединяюил условия 6 кон - 
силрукииях НЕБЕ для повышения илочно- 
сили оилбора. 


Глава 2 


АЧТО ІМСКЕМЕМТ 

Если эила консилрукция присуилсилвуеил 

6 объявлении силолдиа, ило при каждом 
выполнении команды ІМЅЕВТ для эило- 

го силолдца авиломаилически генерирцеился 
уникальное целочисленное значение. 

Глава 4 


АУС 
Функция возвращаеил среднее арифмеиличе- 
ское для числового силолбца. 


Глава 6 


В 


ВЕТМЕЕМ 
Определение диапазонов значений. 
Глава 2 


0 


СНЕСК СОМЅТВАІМТЅ 

Операции всилавки и обновления с илаблицей 
вВыполняюился илолько 6 илом случае, если 
значения удовлеилворяюил заданному усло- 
вию. 


Глава 11 


СНЕСК ОРТОМ 

Используется при создании обновляемых 
предсилавлений; все операции всилавки и 
обновления должны удовлемлворяиль условию 
М/НЕКЕ 86 определении предсилавления. 


Глава 11 


СООМТ 

Подсчеил количесилва записей в резульила – 
илах запроса ЗЕТЕСТ без их непосредсилвен- 
ного получения. СООМТ возвращаеил одно 
целое значение. 


Глава 6 


СВЕАТЕ ТАВІЕ 

Создание иплаблииы. Для выполнения ко- 
манды необходимо знаиль ИМЕНА и ТИПЫ 
ДАННЫХ силолбиоб. Для получения эилой 
информации следуеил проанализироваиль 
данные, коилорые вы собираелесь хранииль 
6 илаблице. 


Глава 1 


СВЕАТЕ ТАВІЕ А$ 

Создание илаблицы по резульилаилам произ- 
Вольной команды ЅЕГЕСТ. 

Глава 10 


СВЕАТЕ ОЅЕК 

Команда использцется 6 неколорых РСУБД 
для создания учеилной записи пользоваилеля 
и назначения ему пароля. 


Глава 12 


список инструментов 


СКОЅ5 ЈОІМ 

Набор всех комбинаций записей одной ила ~ 
блицы с записями другой илаблицы. Также 

всилречаются другие названия — «декар - 
илово соединение», «декарилово произведе - 
ние» и др. 


Глава 8 


0 


ОЕТЕТЕ 

удаляеил записи данных из илаблицы. Ис- 
пользуйие условие М/НЕВЕ для илочного 
определения удаляемых записей. 


Глава 3 


рІЅТІМСТ 
Выборка илолько уникальных значений, без 
дубликаиов. 


Глава 6 


ОКОР ТАВЬЕ 

Команда удаляёил иладлииц, при создании 
коилорой была допущена ошибка — но эило 
следуеил делать до выполнения команд 
ІМЅЕВТ, заполняющих илаблицу данными. 


Глава 1 


Е 


ЕХСЕРТ 

В резульилаил включаюился записи, вхо ~ 
дящие 6 резульилаилы первого запроса, но 
НЕ ВХОДЯЩИЕ в резульилаилы вилорого 
запроса. 


Глава 10 


577 


дальше » 


6 


СКАМТ 

Команда илочно определяем, какие опера- 
ции могцил Выполняилься пользоваилелем 

с илаблицами и силолбиами, на основании 
предосилавленных ему привилегий. 


Глава 12 


СКОУР ВУ 
Группировка записей мо одинаковым значе- 
ниям силолдиа. 


Глава 6 


ІМТЕКЅЕСТ 

В резульилаил включаются данные, при ~ 
суилсилвующие 6 резульилаилах первого 
И Вилорого запроса. 


Глава 10 


1$ МОЦ 
Условие для проверки неопределенных зна- 
чений МОЦ. 


Глава 2 


| 


МІТ 

Условие определяеил, сколько именно зами – 
сей должен Ввернуиль запрос и с какой зами - 
си следцеил начинаиль. 


Глава 6 


578 


припожение 1 


МАХ и ММ 
МАХ 8озвращаеил наибольшее значение 
силолбиа, а ММ — наименьшее. 


Глава 6 


№ 


МОТ 
Логическое отрицание резульилаила. 


Глава 2 


МОШ и МОТ МОЦ 

При создании базы данных следцеил знаиль, 
какие силолдцы не должны принимать зна- 
чение МО. — эило уиросилиил сорилировку 
и поиск данных. Условие МОТ МОШ. задаеил- 
ся для силолбиов при создании илаблицы. 


Глава 1 


0 


ОКОЕК ВУ 
Резульилаил запроса упорядочиваеился 
по заданному силолдиц. 


Глава 6 


$ 


ЗЕЁКЕСТ * 
Выборка Всех силолдиов илаблииы. 


Глава 2 


В 


Внешний запрос 
Запрос, содержащий внцилренний запрос 
(подзапрос). 


Глава 9 


Внешний ключ 
Силолбец илаблицы, значения коилорого ссыла- 
юился на первичный ключ другой илаблицы. 


Глава 7 


Внутреннее соединение (ИММЕК ОМ) 
Любое соединение, комбинирующее записи 
двух илаблиц по некоилорому условию. 
Глава 8 


Внутренний запрос 
Запрос, находящийся внцилри другого запро- 
са. Также можеил называилься подзапросом. 


Глава 9 


Вторая нормальная форма (2НФ) 
Таблица находиился в 1НФ и не содержиил 
часиличных функциональных зависимосилей. 


Глава 7 


Е 


Естественное соединение 

Внуилреннее соединение без «ОМ». Рабо- 
илаеил илолько ири соединении двух илаблиц, 
содержащих одноименные силолдиы. 


Глава 8 


580 


приложение Ш 


Л 


Левое внешнее соединение (.ЕЕТ ОЧТЕВ 
зом) 

Перебор всех записей ЛЕВОЙ илаблицы 

и поиск для них сооилветлетлвия среди запи- 
сей ПРАВОЙ иладлицы. 


Глава 10 


«Многие-ко-многим» 

Две илаблицы связываюился через соедини - 
илельную иладлицу, благодаря чему многие 
записи первой илаблицы могцил быль свя- 
заны со многими записями вВилорой — 

и наоборои. 


Глава 7 


Н 


Некоррелированный подзапрос 

Подзапрос, коилорый сущесилвуеил сам по 
себе и не содержиил ссылок на данные внеш ~ 
него запроса. 


Глава 9 


Необновляемое представление 
Предсилавление, коилорое не можем ис- 
пользоваилься для всилавки или обновления 
данных базовой илаблииы. 


Глава 11 


0 


Обновляемое представление 

Предсилавление, коилорое позволяеил изме - 
няиль данные в базовых илаблицах. Обновля- 
емые предсилавления должны содержаиль все 
силолбиы МОТ МОШ. своих базовых илаблии. 


Глава 11 


«Один-к-одному» 

Ровно одна запись родиилельской илабли - 
цы связываеился с одной записью дочерней 
илаблицы. 


Глава 7 


«Один-ко-многим» 

Запись одной илаблицы можеил быль свя- 
зана со многими записями другой илаблицы, 
но каждая запись последней можеил быиль 
связана илолько с одной записью 8 первой. 


Глава 7 


| 


Первая нормальная форма (1НФ) 

Каждая запись должна содержать ато- 
марные значения, и каждая запись должна 
обладаиль уникальным иденилификаилором. 


Глава 4 


Первичный ключ (РЕМАКУ КЕҮ) 
Силолдеи или набор силолбиов, значение 
коилорого однозначно иденилифицируеил 
запись 6 илаблиице. 


Глава 4 


список инструментов 


Подзапрос 

Запрос, вложенный в другой запрос. Также 
можеил называилься «внуилренним заиро – 
сом». 


Глава 9 


Правое внешнее соединение 

Правое Внешнее соединение перебираеил все 
записи ПРАВОЙ илаблицы и ищеил для них 
сооплвеилсилвия среди записей ЛЕВОЙ имаб- 
лицы. 


Глава 10 


Представление 

Резульилаил запроса, рассмаилриваемый как 
илаблица. Предсилавления осоденно удобны 
для сокращения сложносили запросов. 


Глава 11 


р 


Рефлексивный внешний ключ 

Внешний ключ илой же илаблицы, 6 коилорой 
он являеился первичным ключом, использу - 
емый для других целей. 


Глава 10 


( 


Самосоединение 

Способ посилроения запроса к одной млабли – 
це илак, как если бы она была двумя иладли- 
цами, содержащими одинаковую информа- 
цию. 


Глава 10 


581 


дальше › 


с-Э 


Составной ключ 

Первичный ключ, сосилоящий из нескольких 
силолдиов, комбинация коилорых образцеил 
уникальное значение ключа. 


Глава 7 


Строковые функции 

Функции, изменяющие копии содержимого 
илексиловых силолдиов, Возвращаемые за- 
просом. Исходные данные осилаюился неиз- 
менными. 


Глава 5 


Схема 

Описание данных, хранимых в базе данных, 
включающее Все объекилы и связи между 
ними. 


Глава 7 


| 


Транзитивная фунциональная зависимость 
Не-ключевой силолдец связан с другим 
не-ключевым силолдиом (-ами). 

Глава 7 


582 приложение Ш 


Третья нормальная форма (ЗНФ) 
Таблица находиился в 2НФ и не имееил 
илранзииливных зависимосилей. 


Глава 7 


9 


Эквивалентное и неэквивалентное 
соединение 

Две разновидносили вВнцилренних соедине- 
ний. Эквиваленилное соединение возвращаеил 
комбинации с равными значениями, 

а неэквиваленилные — с неравными значени- 
ями силолбцов. 


Глава 8 


Экранирование 

Аиосилрофы 6 илексиловых данных необходи – 
мо экранироваиль — удвоением апосилрофа 
или обраилной косой черилой. 

Глава 2 


Линн Бейли 
Изучаем 501. 
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